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1 .0 INTRODUCTION 

Western Digital’s WD42C22C integrates a high 
performance, low cost Winchester formatter/con- 
troller, host interface, a buffer manager, and 
CRC/ECC generator/checker in a single 84-pin 
LSI device. Operating from a single +5V power 
supply, the WD42C22C is implemented in a low 
power CMOS design and is available in an 84-pin 
PLCC or PQFP (Figure 1). Figure 2 is a block 
diagram of the WD42C22C. 

1.1 FEATURES 

• Enhanced host interface 

IBM Personal Computer AT and XT port 
compatible 

Supports AT speeds up to 16 MHz, 1 wait 
state I/O and 0 wait state memory using 
120 ns static RAM (SRAM) 

_ Supports AT speeds up to 16 MHz, 1 wait 
state I/O and 0 wait state memory using 
100 ns SRAM 

Selectable DMA or programmed I/O data 
transfers in all host interface modes 
_ Host port slave mode compatible with ALE 
based peripherals such as the WD33C93 
SBIC 

Host transfer rates up to 4 Mwords/sec for 
AT, 4 MB/sec for XT, 10 MB/sec for SCSI 
Internal 1 2 mA high current drivers for 
direct connection to the XT or AT system 
bus 

• Advanced buffer manager 

Supports 1 :1 interleave without resorting to 
wait states 

Direct interface for up to 32 KB of static 
RAM 

Sustained RAM bandwidth up to 10 MB/sec 
Pipelined host and disk address counters 
Operates as either ring or scatter-gather 
buffer 

Allows full track buffering and facilitates 
look ahead cacheing algorithms 
Adaptable disk controller 
Software selectable MFM, RLL 2,7, or NRZ 
disk interface 

. Software selectable 56 bit ECC, 32 bit 
ECC, or 16 bit CRC 

Software selectable 5, 11 , or 22 bit error 
correction span 
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FIGURE 1. PIN DESIGNATION 


Software selectable default sector lengths 
of 128, 256, 512, and 1024 bytes 
User programmable sector size up to 2048 
bytes 

Software selectable 3 bit or 4 bit head 
number field 

Reads and writes at 1 :1 Interleave 
regardless of the formatted interleave 
_ 1 5 Mbs data transfer rate for MFM and RLL 
24 Mbs data transfer rate for NRZ 
Supports hard or soft sectored formats 
Supports "zero latency" read operations 
Internal defect management of sector and 
track level alternates 
Able to read ESDI defect list format 
Supports sector servo schemes by 
disabling WRITE GATE over servo when 
formatting 

Internal 48 mA drivers and Schmitt trigger 
input receivers for direct connection to the 
drive control cable 
• Integrated support features 

Programmable master/slave mode allows 
two Integrated Drive Electronics (IDE) disks 
on one connector 
Supports both lntel-type(80xx) and 
Motorola-type(68xx) microcontrollers 
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Internal power-qualified reset to detect low 
Vdd 

• Low power sleep mode 

• Available in 84-pin PLCC or 84-pin PQFP 

1.2 DESCRIPTION 
1 .2.1 ENHANCED HOST INTERFACE 

The WD42C22C host interface port directly con- 
nects to the host system bus via internal 1 2 mA 
drivers. When operating in either AT or XT mode, 
all host control, data, and task file address lines 
directly connect to the WD42C22C. Mapping the 
device to the desired host system I/O addresses 
requires external address decode logic. Integrated 
I/O port compatible AT and XT task file registers 
assure system compatibility. 


To satisfy requirements for faster system bus 
rates and data transfers, the WD42C22C can 
operate in 12 MHz or 16 MHz, 1 wait state I/O 
channels (0 wait state memory) of 286 or 386 
microprocessors. DMA or PIO data operations 
transfer at a rate of 4 Mwords/sec (AT mode) or 4 
MB/sec (XT mode). In addition to traditional single 
mode DMA, burst mode DMA transfers are also 
available. 

An alternative host mode, slave mode, allows 
communication between the microcontroller and a 
peripheral device through the host interface. The 
slave device transfers data to the buffer RAM by 
using a slave DMA scheme such as the WD-BUS 
mode in the WD33C93 SCSI bus interface con- 
troller (SBIC). 
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1.2.2 ADVANCED BUFFER MANAGEMENT 

The WD42C22C contains an advanced buffer 
manager satisfying the interface requirements be- 
tween a byte or word wide host interface bus and 
a high speed serial disk interface. Optimized for 
the block oriented data structures of a disk con- 
troller, the WD42C22C can manage multiple sec- 
tor buffers up to 32 KB. Each sector buffer can be 
any size to 2055 bytes. Pipelined host and disk 
address counters enable sustained, simultaneous 
transfers on each port. Sufficient RAM buffer 
bandwidth is available to support 1 :1 interleaved 
20 Mb/sec disk transfers while simultaneously 
performing 16-bit host transfers at a rate in ex- 
cess of 3 Mwords/sec. Achieving maximum RAM 
bandwidth requires using 70 nsec static RAM. 

The pipelined structure of the buffer manager con- 
trols the buffer RAM in either a simple ring struc- 
ture or a more advanced scatter-gather structure. 

1 .2.3 ADAPTABLE DISK CONTROLLER 

The WD42C22C’s versatile design makes the 
device adaptable for a wide variety of disk inter- 
face operations. A designer can select from three 
data formats, MFM, RLL 2,7, or NRZ. Disk data 
rates range up to 15 Mbits/sec with MFM and RLL 
2,7 encoding, while NRZ data rates range up to 
24 Mbits/sec. To support varied data format re- 
quirements, the WD42C22C operates in hard or 
soft sectored mode with programmable sector 
sizes to 2048 bytes and programmable ID PLO, 
data PLO, and GAP lengths. 

Software selectable retry algorithms and 32 or 56- 
bit ECC polynomials enhance data integrity. Data 
integrity can further be ensured through the use of 
the device’s built-in advanced defect manage- 
ment. The WD42C22C can be programmed to 
automatically detect the presence of a previously 
assigned defective sector and identify the location 
of the alternate sector. This allows access to alter- 
nate sectors without the typical additional rotation- 
al latency associated with defect handling. 

With the pipelined architecture of the buffer 
manager, the designer can program the disk con- 
troller to execute "zero-latency" multiple sector 
read operations. In this mode of operation, the 
WD42C22C immediately commences data trans- 


fer to the RAM buffer upon encountering the first 
sector on the desired track. All subsequent sec- 
tors transfer to the buffer within a single rotational 
period. Host transfers begin upon location of the 
first requested sector within the buffer. Simul- 
taneous host and disk transfers continue until all 
sectors are read from the drive. Zero-latency 
operation makes available an entire track of data 
to the host within one rotational period from the 
time the host requested the data. This differs from 
traditional implementations which read the entire 
track within one rotational period AFTER the first 
requested sector has been located. Zero latency 
read operations eliminate the typical one-half rota- 
tional period average latency required to locate 
the first sector in full track data transfers 

The WD42C22C includes an internal power 
qualified reset circuit for power up and power 
down conditions. This circuit eliminates the need 
for costly external circuitry that traditionally per- 
formed this function. 

The WD42C22C features a multiplexed ad- 
dress/data bus on the microcontroller interface 
port and supports both Intel (80XX) and Motorola 
(68XX) type microcontrollers. An internal circuit 
automatically determines the connected 
microcontroller and configures the ports for direct 
interfacing. 

Internal 48 mA drivers and Schmitt triggers input 
receivers provide direct connection to the drive 
control cable. Programmable input polarities as- 
sist in integrated drive electronics (IDE) designs. 

1 .2.4 FLEXIBILITY OF APPLICATION 

As a result of its level of integration, a designer 
can create a wide variety of products. In addition 
to traditional stand alone Winchester controller 
boards, the WD42C22C is ideal for multi-function 
boards, direct system motherboards, and IDE ap- 
plications. Special design considerations within 
the WD42C22C facilitate these applications. 

1 .2.5 TYPICAL APPLICATION 

With an external microcontroller, buffer RAM, and 
a data separator such as the WD10C22B, the 
WD42C22C forms the basis of a Winchester disk 
controller product. For AT and XT applications, 
direct interfacing is available to the system bus. In 
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these applications, the WD42C22C requires ex- 
ternal address decoding to select the primary and 
secondary I/O address range of the WD42C22C. 
Other bus interfaces are supported via auxiliary 
bus controllers such as the WD33C93A SCSI Bus 
Interface Controller. 

For ST506 (MFM) and ST412HP (RLL) applica- 
tions, the WD42C22C directly connects to the 
WD10C22 data separator. (Like the WD42C22C, 
the WD10C22B supports both MFM and RLL en- 
coding methods.) An external microcontroller im- 
plements interfa ce sp ecific control lines, e.g. the 
ST506’s STEP and DIRECTION signals. For 


ESDI applications, the WD42C22C operates in 
NRZ mode. 

1.2.6 PIN DESCRIPTIONS 

This section lists the pin number, signal name, 
and function for all the WD42C22C’s pins. The pin 
descriptions are arranged by functions. Table 1 
describes the pin designations for the host inter- 
face. Table 2 describes the pin designations for 
the local microcontroller interface. Table 3 
describes the pin designations for the buffer inter- 
face. Table 4 describes the pin designations for 
the drive interface. 
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PIN MNEMONIC SIGNAL NAME 

NUMBER 

I/O 

FUNCTION 



HAO 

HA1 

HA2 

HA9/ 

HALE 


HRE 


HWE 


HCS 


IOCS16/ 

DREQ 


PAC K/ 

RCS 


HOST ADDRESS 0 
HOST ADDRESS 1 
HOST ADDRESS 2 
HOST ADDRESS 9/ 
HOST ALE 


HOST RE AD 
ENABLE 


HOST W RITE 
ENABLE 


HOST CH IP 
SELECT 


I/O CHIP SELECT 
16/ 

DMA REQUEST 


DMA ACKNOW- 


LEDGE/ 


RAM CHIP SELECT 


I Schmitt-triggered input. These four inputs are 

I used to address the internal registers. Internal 

I decoding of these address signals is a function 

I/O of the AT/XT and HSMB mode bits. Port com- 
patibility is maintained for both the AT and XT. 
In slave host mode HALE is used by the 
peripheral device to latch the address from 
HDO through HD7. 

I/O Schmitt-triggered in put. H RE is asserted by 
the AT or XT with HCS to read an intern al 
register or the FIFO . In slave mode, HRE is 
asserted when MRE is asserted. It can also be 
asserted by the slave peripheral in DMA mode. 

I/O Schmitt-triggered in put. H WE is asserted by 
the AT or XT with HCS to write an intern al 
register or the FIFO . In slave mode, HRE is 
asserted when MRE is asserted. It is also as- 
serted by the slave peripheral in DMA mode. 

I/O Schmitt-triggered input. HCS should be 
decoded from t he AT or X T add ress bus and is 
used to qualify HRE and HWE for host acces- 
ses. In slave mode, HCS is asserted when the 
local microcontroller is accessing the slave 
device address space. 

0 This output is programm able to function as the 
AT bus signal IOCS16 when the PIO mode is 
selected or as a DMA Request signal (DREQ) 
in the DMA mode. This output is tri-stated at 
power-up and remains tri-stated until the inter- 
face mo de is set by the local microcontroller. 
IOCS16 is an open-drain ouput. DREQ is a 
tri-state output. 

1 Schmitt-triggered input. DACK is asserted by 
the host in response to the DREQ signal 
asserti on in order to complete the DMA hand- 
shake. RCS is used in slave mode to qualify 
host data transfers to/from the FIFO. 


TABLE 1. HOST INTERFACE PIN DESCRIPTION 
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PIN 

NUMBER 

MNEMONIC 

SIGNAL NAME 

I/O 

FUNCTION 

23 

RESET 

RESET 

I/O 

Open-drain output and Schmitt input, can be 
wire-ORed with an external reset. The 
WD42C22C resets all logic except the Task 
File when this input is asserted. On power-up, 
or when requested by the host, this output is 
asserted. 

75 

HDO 

HOST DATA 0 thru 

I/O 

Schmitt-triggered inputs. These 16 pins are 

thru 

82, 

40, 

41, 

42, 

44 

thru 

48 

thru 

HD15 

HOST DATA 15 


used during host 16-bit data transfers, and the 
lower eight bits (HD0-HD7) are used for byte- 
wide host data transfers as well as all com- 
mand and status information transfers. 

74 

INTRQ 

INTERRUPT 

REQUEST 

I/O 

INTRQ indicates to the AT or XT that a data 
blocktransfer is requested or a command has 
been completed. In slave host mode INTRQ is 
asserted by the slave peripheral device. 

83 

Vss 

GROUND 


Ground. 

84 

Vdd 

+5V 


+5V 


TABLE 1. HOST INTERFACE PIN DESCRIPTION (CONT’D) 
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PIN 

NUMBER 

MNEMONIC 

SIGNAL NAME 

I/O 

FUNCTION 

22 

Vss 

GROUND 


Ground. 

24 

MCINT 

uCONTROLER 

INTERRUPT 

0 

This output is used as an interrupt signal in 
order to alert the local microcontroller it is 
necessary to check command parameters or 
status. For the XT mode, MCINT is asserted 
when the controller is selected. 

25 

ALE/AS 

ADDRESS LATCH 
ENABLE/ 

ADDRESS STROBE 

1 

Schmitt-triggered input. ALE is used to latch 
the lower eight address bits from the multi- 
plexed address/data lines (AD7-AD0). AS is 
used for this function when tied to a Motorola 
type microcontroller. 

26 

MRE/DS 

^CONTROLLER 
READ ENABLE 
/DATA STROBE 

1 

Schmitt-triggered input. MRE is asserted by 
the local microcontroller to read an internal 
register or the buffer. DS is used in Motorola 
type microcontrollers to enable the data trans- 
fer. 

27 

MWE/ 

MR/W 

uCONTROLLER 
WRITE ENABLE/ 
uC READ/WRITE 

1 

Schmitt-triggered input. MWE is asserted by 
the local microcontroller to write an internal 
register or the buffer. MR/W is used by 
Motorola type microcontrollers to set the direc- 
tion of data transfers. 

28 

ADO 

ADDRESS/DATA 0 

I/O 

Schmitt-triggered inputs. These multiplexed 

thru 

thru 

thru 


address/data lines are used to load the 

35 

AD7 

ADDRESS/DATA 7 


register/buffer address on the falling edge of 
ALE, and are used for data transfers to/from 
the local microcontroller. 

43 

Vss 

GROUND 


Ground. 


TABLE 2. LOCAL MICROCONTROLLER INTERFACE PIN DESCRIPTION 


32 
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PIN 

NUMBER 

MNEMONIC 

SIGNAL NAME 

I/O 

FUNCTION 

38 

XTALIN 

CRYSTAL 

1 

Crystal oscillator input. The crystal frequency 



INPUT 


is twice the buffer data rate. 

39 

XTALOUT 

CRYSTAL 

OUTPUT 

0 

Crystal oscillator output. 

49 

BOE 

BUFFER OUTPUT 

0 

BOE is asserted by the chip to read data from 



ENABLE 


the external SRAM buffer. 

50 

BWE 

BUFFER WRITE 

0 

BWE is asserted by the chip to write data into 



ENABLE 


the external SRAM buffer. 

51 

BDO 

BUFFER DATA 0 

I/O 

Schmitt-triggered. Buffer data bus, which con- 

thru 

thru 

thru 


nects directly to a static RAM. 

58 

BD7 

BUFFER DATA 7 


59 

BAO 

BUFFER ADDRO 

I/O 

Buffer address bus, for direct connection to 32 

thru 

thru 

thru 


KB of SRAM. In XT mode, also used to read 

73 

BAM 

BUFFER ADDR 14 


jumper configuration data in Read Configura- 
tion Mode. In input mode, there is a low cur- 
rent internal pulldown. 


TABLE 3. BUFFER INTERFACE PIN DESCRIPTION 
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PIN 

NUMBER 

MNEMONIC 

SIGNAL NAME 

I/O 

FUNCTION 

10 

WD 

WRITE DATA 

0 

WD is the MFM/NRZ write data written to the 
disk. It is shifted out at a rate determined by 
write clock. MFM write data should be 
synchronized by a D flip flop clocked at 10 
MHz (for 5 Mbs operation). 

11 

LATE/ 

LATE/ 

0 

LATE is used along with EARLY in the Write 


WCOUT 

WCOUT 

0 

Precompensation circuitry to control the delay 
of WD. 

In NRZ mode WCOUT is write clock out which 
can be used to qualify WD in an ESDI applica- 
tion. 

12 

AME/ 

EARLY 

ADDRESS MARK 
ENABLE/EARLY 

0 

In NRZ mode, this output is the Address Mark 
Enable signal for an ESDI drive. In MFM or 
RLL mode, this output is EARLY. EARLY and 
LATE are used in the Write Precompensation 
circuitry to control the delay of WD. 

13 

WG 

WRITE GATE 

0 

WG is asserted when valid data is to be written 
to the disk. It enables write current to the head 
and is immediatelv de-asserted if a WRITE 
FAULT (WF) is detected. 

14 

WC 

WRITE CLOCK 

1 

A clock used internally to control WD. (Up to 

1 0 MHz for ST41 2, up to 1 5 MHz for ESDI). 

15 

INDEX 

INDEX 

1 

Schmitt-triggered INDEX input for direct con- 
nection to the drive control cable. 

16 

SCT/ 

DRUN 

SECTOR/ 

DATA RUN 

1 

Schmitt-triggered input. In hard sector mode, 
SCT is used to indicate the start of a sector. In 
soft sector NRZ mode, SCT indicates Address 
Mark Found. In soft sector MFM or RLL mode, 
DRUN indicates a sequence of MFM or RLL 
’0’s or a sequence of MFM Ts has been 
detected. 

17 

RD 

READ DATA 

1 

RD is MFM or NRZ read data from the drive. 
Data and clocks are separated internally for 
MFM data. 

18 

RG 

READ GATE 

0 

RG is asserted to initiate a search for an ad- 
dress mark. It remains asserted until the end 
of the ID or data field. 


TABLE 4. DRIVE INTERFACE PIN DESCRIPTION 
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PIN 

NUMBER 

MNEMONIC 

SIGNAL NAME 

I/O 

FUNCTION 

19 

RC 

READ CLOCK 

1 

RC is typically generated from an oscillator 
phase-locked to the read data. 

20 

WF 

WRITE FAULT 

1 

Schmitt-triggered. WRITE FAULT input for 
direct connection to the drive control cable. 

21 

DRDY 

DRIVE READY 

1 

Schmitt-triggered. DRIVE READY input for 
direct connection to the drive control cable. 

36 

DS0 

DRIVE SELECT 0 

0 

High-current open-drain DRIVE SELECT out- 

37 

DS1 

DRIVE SELECT 1 

0 

puts for direct connection to the drive control 
cable. 


TABLE 4. DRIVE INTERFACE PIN DESCRIPTION (CONT’D) 


2.0 ARCHITECTURE 

2.1 POWER-QUALIFIED RESET 

This integrated function is used to reliably initialize 
flip-flops to a predictable state du ring the applica- 
tion of Vdd- It causes the RESET output signal to 
be asserted until VDD reaches a given threshold. 
It also forces a reset if the Vdd falls below a 
specified threshold. 

2.2 DRIVE INTERFACE LOGIC 

The drive interface contains high-current 48 mA 
drivers for direct connection of the drive select 
outputs to the drive control cable. Schmitt trigger 
input receivers connect the drive interface logic 
directly to the control cable inputs. 

2.3 DRIVE CONTROLLER ORGANIZATION 

The controller is composed of the following major 
sections: 

• PLA Control 

• CRC/ECC Logic 

• MFM/RLL Decoding 

• Address Mark Detector 

• Buffer and DMA Control 

• Task Register File 

The controller is designed to operate with 2 clock 
inputs, READ CLOCK (RC) and WRITE CLOCK 
(WC). The PLA controller, processor interface, 
and buffer control sections use the write clock 
input. The clock inputs are used for MFM, RLL, or 
NRZ decoding. The clock frequency is 10 MHz for 
a 10 Mbs data rate. 


The controller reads or writes disk data to a 15 
Mbs rate for MFM and RLL and 24 Mbs for NRZ. 
The RLL implementation is a (2, 7, 2, 4, 3) code 
based on the IBM 3370 code. The only difference 
lies in the assignments of the code words to the 7 
different data streams possible. Error propagation 
for a single bit error is limited to 4 bits. 

When programmed in the NRZ mode, the 
WD42C22C qualifies NRZ disk data using the 
Sector / Address Mark Detect signal, and also 
modifies the RG and WG signals to meet ESDI 
specifications. 

In all modes, the length of the PLO sync and gap 
fields are software programmable. The ID PLO 
sync field length, the Gap1/Gap3 length, the 
Gap1/Gap3 data bytes and the ID CRC pad 
bytes are programmable during the format com- 
mand. The data PLO sync field length and the 
data CRC/ECC pad bytes are programmable 
during the Write command. 

Figure 3 is a block diagram of the drive controller 
section of the WD42C22C. 

2.4 PROGRAMMABLE LOGIC ARRAY (PLA) 
CONTROLLER 

The Programmable Logic Array (PLA) controller 
interprets commands, e.g. write, read format, etc. 
This circuitry’s operation is synchronized with the 
WC input. The PLA controller is started when a 
command is written into the command register. It 
generates control signals and operates in a hand- 
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NC indicates no connection to the chip pins. 

FIGURE 3. DRIVE CONTROLLER BLOCK DIAGRAM 


shake mode when communicating with the 
MFM/RLL decoding block. The MFM/RLL decod- 
ing block uses the RC input which may be 
asynchronous to WC. 

2.5 MAGNITUDE COMPARATOR 

An 11 -bit magnitude comparator calculated drive 
step direction and number of step pulses be- 
tween present cylinder position and desired posi- 
tion in earlier Winchester controller versions. This 
comparator is not used in the WD42C22C. A 
separate high speed equivalence comparator is 
used to compare ID field bytes when searching for 
a sector ID field. 


2.6 CRC/ECC GENERATOR AND CHECKER 

The CRC/ECC generator computes and checks 
the cyclic redundancy check characters appended 
to the ID and data fields written on the disk. The 
CRC mode of operation, defined by the SDH 
register (bit 7 set to 0) provides a means of verify- 
ing the accuracy of the data read from the disk but 
does not attempt to correct it. (Bit 7 of the SDH 
register will not implement CRC mode for data 
fields when RLL mode is selected.) The CRC 
polynomial used is: 

X 16 + X 12 +X 5 + 1 

The CRC register is preset to all ones before 
computation starts. 
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If the CRC character being generated while read- 
ing the data does not equal the one previously 
written, an error exists. If there is a CRC failure in 
the ID field, an ID not found is indicated by setting 
bit 4 of the error register. If the failure is in the 
data field, bit 6 of the error register is set. 

A 32 bit or 56 bit ECC polynomial may be 
selected instead of the CRC polynomial for the 
data field. The CRC/ECC selection is controller by 
bit 7 of the SDH register when the controller is in 
MFM or NRZ modes. CRC is selected when bit 7 
of the SDH register is 0 in MFM or NRZ modes. 
ECC is selected when bit 7 of the SDH register is 
1 in MFM or NRZ modes. Bit 2 in the set 
parameter command selects either the 32 bit or 
56 bit polynomial. RLL mode defaults to the 56 bit 
polynomial. The CRC or 32 bit ECC options are 
not usable in RLL mode. 

The ECC mode of operation (SDH bit 7 = 1) is 
only applicable to the data field. This feature built 
into the WD42C22C provides the user with the 
ability to detect and correct errors in the data field 
automatically. 

The following is a summary of the parameters 
considered when ECC is used: 

• 1 . SDH register bit 7. 

• 2. Read and write command bit 1 (L). 

• 3. Compute correction command. 

• 4. Set parameter command. 

• 5. Error occurred, bit 0 of the status register. 

• 6. On any ECC error the controller stops 
regardless of the T bit. (Refer to the read com- 
mand description.) 

The SDH register bit 7 must be equal to one to 
change from the CRC mode to the ECC mode, for 
MFM and NRZ only. 

When an ECC error is detected, no attempt is 
made to correct it and bit 0 of the status register 
and bit 6 of the error register are set. The user 
now has two choices: 

• 1 . Ignore the error and make no attempt to 
correct it. 

• 2. Use the compute correction command to 
determine the pattern and location of the error, 
and correct it within the user’s program. 


When implementing the compute correction com- 
mand, use it before executing commands that 
alter the content of the ECC register. The read, 
write, scan, and format commands can alter the 
syndrome and make correction impossible. If the 
compution correction command determines that 
the error is uncorrectable, then the error bits in the 
status register and error register are set. 

Although ECC generation starts with the first bit of 
the F8 byte in the data ID field, the actual ECC 
bytes produced for the sector are the same as if 
the A1 byte was included. 

The 32-bit ECC polynomial is: 

x 32 + X 28 + X 26 + X 19 + X 17 + x 10 + X 6 + X 2 + 1 

and is the same one used in the WD1002, 
WD1003, and WD1006 controller boards. The 32- 
bit ECC polynomial has an 11 bit maximum single 
burst correction span. The reverse 32-bit ECC 
polynomial is: 

x 32 + X 30 + X 26 + X 22 + X 15 + X 13 + X 6 + X 4 + 1 

The non-detection probability for the 32-bit ECC 
polynomial is: 

2.3 (E-10), r + = 516x8, b f = 5 
and the miscorrection probability is: 

1.57 (E-5), r' = 516 x 8, = 5 

The 56-bit ECC polynomial is: 

x 56 + X 52 + X 50 + X 43 + X 41 + X 34 + X 30 + X 26 + 
X 24 + X 8 + 1 

The 56-bit ECC polynomial has a 22 bit maximum 
single burst correction span. 

The reverse 56-bit ECC polynomial is: 

x 56 + X 48 + X 32 + X 30 + X 26 + X 22 + X 15 + X 13 + 
X 6 + X 4 + 1 

The non-detection probability for the 56-bit ECC 
polynomial is: 

1.39 (E-17), ^ = 519x8, b + =11 
and the miscorrection probability is: 

5.84 (E-11), r = 519 x 8, b f = 11 
The set parameter command selects the number 
of bits in the correction span, through the use of 
bit 0. 
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Read and write commands, with the L bit (bit 1) 
set to one, are referred to as read long and write 
long commands. With these commands, no ECC 
or CRC characters are generated or checked by 
the WD42C22C. In effect, the four or seven bytes 
are handled as an additional four or seven bytes 
of data which pass through the data buffer. With 
proper use of the write, read long, write long, and 
read commands, a diagnostic routine may be 
developed to test the accuracy of the error correc- 
tion process. 

For CRC/ECC calculations, the CRC/ECC 
register is initialized to all 1’s. For CRC/ECG pur- 
poses only, the address mark byte has a value of 
"A1" and is included in the CRC/ECC calcula- 
tions. 

2.7 MFM/RLL ENCODING AND MFM/RLL 
DECODING 

The MFM/RLL encoding section receives 8-bit 
parallel data and generates either MFM or RLL 
write data depending on the K option in the load 
parameter block command. This section operates 
with a write clock having a frequency of the 
desired bit rate. The write clock need not be 
synchronized to read clock (RC). 

Data bytes are written to the drive most significant 
bit first. The MFM/RLL decoding section 
generates 8 bit binary data from MFM or RLL read 
data once an address mark has been detected. 
Table 5 lists the RLL coding rules followed by the 
controller. 


NRZ Data RLL Code Word Output 

First Bit Last Bit First Bit Last Bit 


1 

1 

X 

X 

10 0 0 

xxxx 

1 

0 

X 

X 

0 10 0 

xxxx 

0 

1 

1 

X 

0 0 10 

0 oxx 

0 

1 

0 

X 

0 0 0 1 

0 oxx 

0 

0 

0 

X 

10 0 1 

0 oxx 

0 

0 

1 

1 

0 0 0 0 

1 000 

0 

0 

1 

0 

0 0 10 

0 100 


TABLE 5. RLL CODING RULES 


When NRZ mode is selected, the MFM/RLL en- 
code and decode logic is bypassed. NRZ read 
data is clocked in on the rising edge of Read 
Clock and NRZ write data is clocked out on the 
rising edge of WC. 

2.8 ADDRESS MARK DETECTOR 

An address mark is a unique 2 byte code placed 
at the beginning of each ID field or data field. A 
series of zero bytes always precedes each ad- 
dress mark. The address mark detector section 
begins searching for an address mark when 
synchronization has been lost after a series of 
zero bytes is detected. The detection of an ad- 
dress mark establishes resynchronization. 

The address mark is composed of a 2 byte se- 
quence. The first byte is used for resynchroniza- 
tion and the second byte specifies ID or data field. 
For the MFM mode, the first byte is an A1i6 byte 
with missing clock (data = A1 , clock = OA). The 
second byte is encoded with normal MFM rules. 
FF through FC and F7 through F4 specify the 
beginning of an ID field and F8 specifies the 
beginning of a data field. 

In RLL mode, the first byte is a unique code which 
violates normal RLL coding rules but does not vio- 
late the 2,7 timing rule. The RLL address mark 
pattern is 1000 0000 1001 0000 (8090 i 6 ). The 
second byte is encoded with normal RLL rules. 
FF through FC and F7 through F4 specify the 
beginning of an ID field and F8 specifies the 
beginning of a data field. 

In NRZ mode, an NRZ A1 byte establishes byte 
synchronization. When the WD42C22C is used to 
control an ESDI (NRZ) drive, the Sector Pulse 
(Address Mark Found) signal will qualify read data 
to prevent false address mark detection. 

2.9 CONTROLLER TO DATA SEPARATOR 
INTERFACE 

The read interface section generates READ 
GATE (RG) from signals sent by the PLA control- 
ler and by the DRUN input. In this system, raw 
read data from the drive is presented to the RD in 
put. RG is low when the controller is not inspect- 
ing read data. When a read command is started 
and a search begins for an address mark, DRUN 
from the data separator is examined. Since each 
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address mark should be preceded by ap- 
proximately 12 bytes of zeroes, RG is activated 
when a sequence of zeroes is detected by DRUN 
and read data is examined until either an address 
mark is detected or a non-zero byte which is not 
an address mark is detected. If an address mark 
was detected, and it was preceded by at least 8 
bytes of zeroes, read gate is held high and the ID 
or data field can be read. 

If a non-zero non-address mark byte was 
detected, then RG is dropped for at least 2 byte 
times, allowing the phase lock loop to 
resynchronize with WC, before inspecting DRUN 
input again. If the desired ID field was read, then 
the sector transfer can be made. If a data field 
was detected or if the ID bytes did not match, or if 
an address mark was not preceded by eight bytes 
of zeroes with six coming after RG on, then RG is 
lowered and DRUN is inspected again for a se- 
quence of zeroes. 

Figures 4 illustrates the PLL control sequence for 
the ID field. Figure 5 illustrates the PLL control 
sequence for the data field. 



FIGURE 4. PLL CONTROL (ID FIELD) 
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The write precompensation circuitry, in the con- 
troller to the drive interface, reduces the effects 
one bit has on another. There are two parts to 
write precompensation logic, reduced write cur- 
rent (RWC) and shifting of the bits as they are 
written. The RWC is NOT controlled by the drive 
controller. The local microcontroller should specify 
when the write current is reduced by asserting its 
own RWC output. 

The sh ifting of the data bits is controlled by the 
EARLY and LATE outputs. These two outputs 
should be used to delay the output as follows in 
Table 6: 


EARLY LATE DELAY 

0 1 no 

delay 

1 1 one unit 

delay 

1 0 two units 

delay 


TABLE 6. EARLY AND LATE DELAYS 


The EARLY and LATE outputs are generated ac- 
cording to the rules in Tables 7 (RLL) and 8 (MFM 
or NRZ). 
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RLL Coded Data Pattern 

Preceding 

Bits 

Comp. 

Bit 

Following 

Bits 

Precomp 

X 1 0 0 

1 

0 0 0 X 

EARLY 

X 0 0 0 

1 

0 0 0 X 

None 

X 0 0 0 

1 

0 0 1 X 

LATE 

0 10 0 

1 

0 0 10 

None 


TABLE 7. EARLY AND LATE GENERATION 
(RLL MODE) 
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MFM Coding - NRZ Data Pattern 


Preceding 

Bits 

Comp. 

Bit 

Following 

Bits 

Precomp 

XXXI 

1 

0 X X X 

EARLY 

X X X 0 

1 

1 X X X 

LATE 

X X 0 0 

0 

1 X X X 

EARLY 

X X 1 0 

0 

0 X X X 

LATE 


TABLE 8. EARLY AND LATE GENERATION 
(MFM - NRZ) 


3.0 INTERFACE PORTS AND TASK 
FILES 

3.1 HOST INTERFACE ORGANIZATION 

The WD42C22C’s host interface directly connects 
to the IBM XT or IBM AT system bus as well as 
the system bus of any XT or AT compatible. The 
WD42C22C has high current drivers which allow 
it to be directly connected to the system bus. 

The register configuration for the hos t interface is 
dependent on the state of the AT/XT control bit in 
the interface control register which is written by 
the local microcontroller. 

There is an additional slave host mode. In this 
mode, the microcontroller communicates to a 
peripheral device with up to 32 registers through 
the host interface. The slave device can transfer 
data to/from the buffer RAM by using a slave DMA 
scheme such as the WD-BUS mode in the SBIC. 

The sequence that the microcontroller follows to 
transfer data between the buffer RAM and the 
host is defined under the buffer manager descrip- 
tion. 

3.2 XT HOST INTERFACE 

To put the WD42C22C in the XT compatible inter- 
face mode the local microcontr oller resets the 

AT/XT control bit. In this mode, HCS should be 
active when I/O ports 320 (hex) through 323 (hex) 
are addressed. (XT I/O ports 320 through 323 are 
primary ports. XT I/O ports 324 through 327 are 
secondary ports. Unless otherwise noted, infor- 
mation regarding the primary ports is identical to 


information on secondary ports.) Table 9 lists the 
port descriptions for this mode. 


HA9 HA2 HA1 HAO 

READ 

PORT 

WRITE 

PORT 

X 

X 

0 

0 

Read data 

Write data 

X 

X 

0 

1 

Hardware 

status 

Hardware 

reset 

X 

X 

1 

0 

Drive con- 
figuration 

Drive 

select 

X 

X 

1 

1 

NOT 

USED 

DMA and 

interrupt 

control 


TABLE 9. XT PORT DESCRIPTIONS 


3.2.1 READ DATA PORT (HA1 THRU HAO = 0, 
READ) 

The read data port is used to send data and 
status to the host processor. The data read from 
this port comes from the buffer RAM under the 
control of the buffer manager. 

3.2.2 WRITE DATA PORT (HA1 THRU 
HAO = 0, WRITE) 

The write data port is used to send commands 
and data from the host to the drive controller. 
The data is written to the buffer RAM under the 
control of the buffer manager. 

3.2.3 HARDWARE STATUS (HA1 THRU 
HAO = 1, READ) 

This port contains the controller hardware status. 
It can be read by the host at any time. Bit 7, bit 6, 
bit 2, and bit 1 are written by the local 
microcontroller. Bit 5, bit 4, bit 3, and bit 0 are 
controlled by internal logic. The bits are defined 
as follows: 


Bit 

7 

6 

5 

4 3 

2 

1 

0 

X 

X 

IRQ 

DRQ XBSY 

C/D 

I/O 

REQ 


3.2.3. 1 BIT 5 INTERRUPT REQUEST 

This bit signifies that an interrupt is pending. 
IRQ reflects the state of the INTRQ output. The 
INTRQ pin is tri-stated and the IRQ status bit 
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and internal interrupt flip-flop are reset when 
the host disables the interrupt or when the 
WD42C22C is reset, either by the host or by as- 
serting master reset. 

3.2.3.2 BIT 4 DMA REQUEST 

This bit signals that the WD42C22C is ready for a 
DMA transfer to take place. The direction of the 
transfer is determined by the I/O bit. This bit 
reflects the state of the DREQ output. 

3.2.3.3 BIT 3 XT BUSY 

This bit indicates that the WD42C22C is busy ex- 
ecuting a command and is unable to accept 
another command. This bit is set by during a 
reset. 


3.2.3.4 BIT 2 COMMAND / DATA 

This bit tells the host which type of transfer is 
expected at the read and write data ports. C/D 
set to 1 indicates that a_ command or status 
transfer is expected. C/D set to 0 indicates 
that a data transfer is expected. 

3.2.3.5 BIT 1 INPUT / OUTPUT 

This bit tells the host the_direction of transfer 
for the two data ports. I/O set to 1 indicates 
an input (read) by the host and I/O set to 0 in- 
dicates an output (write) by the host. 

3.2.3.6 BIT 0 REQUEST 

This bit is one of the handshaking signals be- 
tween the host and WD42C22C. When transfer- 
ring data to/from, the WD42C22C’s read data and 
write data ports by the host, assertion of this bit 
informs the host that the WD42C22C is ready for 
the transfer. 

3.2.4 CONTROLLER RESET (HA1 THRU 
HA0 = 1, WRITE) 

When this port is written, regardless of the data 
written, the RESET output is asserted if enabled. 
If the reset has been disabled by the local 
microco ntroller, then writing to this port asserts 
MCINT and the local microcontroller is respon- 
sible for resetting the logic on the drive controller 
board. 


3.2.5 DRIVE CONFIGURATION INFORMATION 
(HA1 THRU HAO = 2, READ) 

This register, when read, informs the host about 
the configuration of the drive(s) attached. This 
configuration information is written by the local 
microcontroller. 

3.2.6 CONTROLLER SELECT 
(HA1 THRU HAO = 2, WRITE) 

When this p ort is w ritten, regardless of the data 
written, the MCINT output is asserted to inform 
the local microcontroller that the controller board 
has been selected. 

3.2.7 DMA AND INTERRUPT MASK 
(HA1 THRU HAO = 3, WRITE) 

This port enables or disables the DMA and inter- 
rupt to the host. When IRQEN is set to 1, then 
interrupts to the host are enabled. This bit is 
cleared when the WD42C22C is reset. The 
INTRQ line is tri-stated and the host interrupt is 
cleared when the interrupts are disabled. When 
DRQEN is set to 1 , then DMA requests to the host 
are enabled. This bit is cleared when the 
WD42C22C is reset. 


Bit 

7 

6 

5 

4 

3 

2 

1 

0 

X 

X 

X 

X 

X 

X 

IRQ 

DRQ 







EN 

EN 


3.3 AT HOST INTERFACE 

To put the WD42C22C in the AT compatible inter- 
face mode, the AT/X T cont rol bit is set by the local 
microcontroller. The HCS chip select should be 
active when I/O ports 1F0i6 through 1F7i6 and 
3F6i6 and 3F7i6 are addressed for primary ad- 
dressing and for I/O ports 170i6 through 177i6 
and 376i6 and 377i6 for secondary addressing. 
Only address signals HA8 through HA3 and AEN 
need to be decoded to generate HCS. Table 10 
describes the ports for AT mode as follows: 
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ABSY HA9 

HA2 

HA1 HAO READ 

PORT 

AT TASK FILE COPY 

WRITE 

PORT 


0 

0 

0 

0 

0 

Read Data 

Write Data 






(16 bits) 

(16 bits) 

0 

0 

0 

0 

1 

Host Error 

Register 

Write Precomp 

Cylinder 

0 

0 

0 

1 

0 

Sector Count 

Sector Count 

0 

0 

0 

1 

1 

Sector Number 

Sector Number 

0 

0 

1 

0 

0 

Cylinder Number 

Low 

Cylinder Number 

Low 

0 

0 

1 

^ 0 

1 

Cylinder Number 

High 

Cylinder Number 

High 

0 

0 

1 

1 

0 

SDH 

SDH 

0 

0 

1 

1 

1 

Host Status 

Register 

Host Command 

Register 

1 

0 

X 

X 

X 

Host Status Register 

INVALID 

CONTROL PORTS 

X 

1 

1 

1 

0 

Alternate Status 
Register 

Fixed Disk 

Register 

X 

1 

1 

1 

1 

Digital Input Register* 

NOT USED 


*Bit 7 is tri-stated when the digital input register is read to accomodate the floppy disk change status. 

___ TABLE 10. AT MODE PORT DESCRIPTIONS 


When port 0 is accessed the IOCS 16 output is 
asserted when in AT programmed I/O mode. All 
buffer data transfers are 16 bits. The ECC byte 
transfers in a long mode (read or write) are 8 bit 
transfers. All other register transfers are 8 bits. 

Registers 1 through 7 are an identical copy of the 
drive controller task registers 1 through 7. These 
registers can be read or written by the host only 
when the ABSY status bit is not active. Any at- 
tempt by the host to read the AT task file copy 
while ABSY is active results in the host status 
register being read. The AT task file copy registers 
cannot be written by the host while ABSY is ac- 
tive. 

3.3.1 ERROR REGISTER 

(HA9, HA2 THRU HAO = 01 , READ) 

The error register is read only and contains the 
specific error status pertaining to a command. The 
meaning of the status register bits are as follows: 


Bit 

7 

6 

5 

4 

3 

2 1 0 

BB 

CRC/ 

ECC 

0 

IDNF 

0 

AC TKO DMNF 


3.3.1 .1 BIT 7 BAD BLOCK 

A bad block address mark has been detected 
when trying to read or write that sector. The data 
field will not be read or written. 

3.3.1 .2 BIT 6 CRC/ECC DATA FIELD ERROR 

An uncorrectable ECC error or a CRC error was 
detected in the data field. 

3.3.1 .3 BIT 5 RESERVED 

Not used, forced to zero. 

3.3.1 .4 BIT 4 ID NOT FOUND 

Occurs when cylinder, head, sector, size para- 
meters with a correct ID field CRC cannot be 
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found. For read and write sector commands, with 
the retry disable bit reset, this bit indi- 
cates that after 10 index pulses, an auto-scan 
ID and auto-seek, and 10 more index pulses, no 
matching ID field was found. If the retry disable 
bit is set, then no matching ID field was 
found after 2 index pulses; no auto-scan or 
auto-seek is performed. 

3.3.1. 5 BIT 3 RESERVED 

Not used, forced to zero. 

3.3.1 .6 BIT 2 ABORTED COMMAND 

Set if command was started and one of the follow- 
ing conditions occurred: 

• 1 . Drive not ready 

• 2. Write fault 

• 3. Illegal command code. 

3.3.1 .7 BIT 1 TRACK 0 ERROR 

This bit, when set, indicates an error detect- 
ing Track 0 during a restore. 

3.3.1 .8 BIT 0 DATA ADDRESS MARK NOT 
FOUND 

Set if the first two bytes of the data field fol- 
lowing an ID match are not A1 F8. This condition 
is checked for read sector commands only. 

3.3.2 WRITE PRECOMP CYLINDER 
REGISTER (HA9, HA2 THRU HAO = 01, 
WRITE) 

This register is used to control the Reduce Write 
Current (RWC) signal going to the drive. RWC is 
turned on if the present position cylinder number 
is greater than or equal to the 4 times the write 
precomp cylinder number. If the write precomp 
cylinder number is FFi6, then the RWC is never 
asserted. 

3.3.3 SECTOR COUNT (HA9, HA2 THRU HAO 
= 02, READ/WRITE) 

This register is used in read sector, write sector, 
and format commands to implement multiple sec- 
tor handling with one command. A value of 1 indi- 
cates a single sector transfer, a value of 2 indi- 
cates a 2 sector transfer, and so forth. A value of 
0 indicates a 256 sector transfer. Sector count is 
decremented and the sector number is incre- 


mented after each sector transfer between the 
buffer and host or drive. 

3.3.4 SECTOR NUMBER (HA9, HA2 THRU 
HAO = 03, READ/WRITE) 

The sector number register is used to hold the 
number of the desired sector for read and write 
commands. The sector number can range from 0 
to 255. 

3.3.5 CYLINDER NUMBER LOW AND HIGH 
REGISTERS (CYLINDER NUMBER 
LOW: HA9, HA2 THRU HAO r 04, 
READ/WRITE. CYLINDER NUMBER 
HIGH: HA9, HA2 THRU HAO = 05, 
READ/WRITE) 

These registers specify the cylinder number for 
read, write, and format commands. The cylinder 
number may range in value from 0 to 2047. 
Cylinder number low register holds the 8 least sig- 
nificant bits of the desired cylinder number. 
Cylinder number high register holds the three 
most significant bits of the desired cylinder num- 
ber in bits 0 through 2. Bits 3 through 7 are not 
normally used in disk controller boards. These bits 
are latched when writing to this register. This 
means that all 8 bits can be used to transfer infor- 
mation between the host and the local microcon- 
troller. 

3.3.6 SDH REGISTER (HA9, HA2 THRU HAO = 
06, READ/WRITE) 

This register is used to specify the desired drive 
and head numbers and to specify CRC or ECC 
mode. 


Bit 

7 

6 

5 

4 

3 2 10 

CRC/ 

ECC 

0 

SS 

Drive 

Number 

Head Number 


3.3.6.1 BIT 7 ECC/CRC SELECT 

This bit is set for data field ECC mode. It is 
reset for data field CRC mode. 


3.3.6.2 BIT 5 SECTOR SIZE 

Bit 5 (SS0) is used to select sector size. If SS0 
= 0, then the sector size is 256 bytes and if SS0 
= 1 , then the sector size is 512 bytes. 


ADVANCED INFORMATION 12/4/90 


33-19 






WD42C22C 


INTERFACE PORTS AND TASK FILES 


3.3.6.3 BIT 4 DRIVE SELECT 

Bit 4 specifies the desired drive number. This bit 
also determines which of the two internal drive 
status registers are read when the host accesses 
the host status register or alternate status 
register. If DS = 0, the host receives drive zero 
status. If DS = 1 , then the host receives drive one 
status. 

3.3.6.4 BITS 3 THROUGH 0 HEAD NUMBER 

Bits 3, 2, 1 and 0 specify the desired head num- 
ber. 

3.3.7 HOST STATUS REGISTER 

(HA9, HA2 THRU HAO = 7, READ) 

The status register reads only and reflects the 
status of the controller as well as the status of 
certain drive control lines. Some of the status bits 
are controlled by the local microcontroller. Drive 
status comes from two registers in the 
WD42C22C, one for each drive. Bit 4 of the SDH 
register in the AT task file copy controls which of 
the two registers is read when the host reads this 
port. Reading of the status register by the host 
resets INTRQ. The description of the status 
register bits follows: 


Bit 

7 6 

5 

4 

3 2 1 

0 

ABSY RDY 

WF 

sc 

DRQ DWC IDX 

ERR 


3.3.7.1 BIT 7 AT BUSY 

This bit is set to 1 when the controller is ac- 
cessing the disk. ABSY is activated by the 
start of a command (writing into the host com- 
mand register). It is deactivated at end of all 
commands by the local microcontroller. This 
bit is also set during a reset. 

3.3.7.2 BIT 6 DRIVE READY 

This bit reflects the state of the DRDY drive 
status pin. Any command aborts if DRDY is low. 
This bit is written by the local microcontroller. 

3.3.7.3 BIT 5 WRITE FAULT 

This bit reflects the state of the WF drive status 
pin. Any command aborts if WF is high. This bit 
is written by the local microcontroller. 


3.3.7.4 BIT 4 SEEK COMPLETE 

This bit reflects the state of the SC signal com- 
ing from the drive. This bit is written by the 
local microcontroller. 

3.3.7.5 BIT 3 DATA REQUEST 

This bit is asserted when the host should be 
transferring data between the RAM buffer and 
host. This bit is controlled by the buffer 
manager. 

3.3.7.6 BIT 2 DATA WAS CORRECTED 

This bit indicates that an error in the data 
field was detected and corrected. The buffer 
contains corrected data. This bit is written by 
the local microcontroller. 

3.3.7.7 BIT 1 INDEX 

This bit reflects the state of the INDEX pin. 

3.3.7.8 BIT 0 ERROR 

This bit indicates that a non-recoverable error 
has occurred. The error register describes the 
error condition when this bit is active. This 
bit is written by the local microcontroller. 

3.3.8 HOST COMMAND REGISTER 
(HA9, HA2 THRU HAO = 7 , WRITE) 

The command to be executed is written into this 
register. Writing this register s ets AB SY in the 
status register and asserts the MCINT pin going 
to the local microcontroller. The command latches 
in a register which the local microcontroller reads. 
Writing this register resets INTRQ. 

3.3.9 ALTERNATE STATUS REGISTER 
(HA9, HA2 THRU HAO = E, READ) 

This register is the same as the host status 
register (7) but mapped at a different address. 
Refer to page 23 for the bit description. 

3.3.10 FIXED DISK REGISTER 

(HA9, HA2 THRU HAO = E, WRITE) 

The fixed disk register is used by the host to con- 
trol some of the internal functions of the 
WD42C22C. Bit 0 and bits 4 through bit 7 are 
reserved for future definition. These bits are cur- 
rently not used in the AT protocol but they are 
implemented in the WD42C22C, i.e. the fixed disk 
register passes 8 bits between the host and the 
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local microcontroller. The host should write zeroes 
to these bits in AT mode. The fixed disk register is 
coded as follows: 


Bit 

7 

6 

5 

4 3 2 1 

0 

0 

0 

0 

0 HS3ENRSTIEN 

0 


3.3.10.1 BIT 3 HEAD SELECT 3 ENABLE 

When HS3EN = 1 , then HEAD SELECT 3 is as- 
serted by the local microcontroller. When HS3EN 
= 0, then RWC is asserted by the local microcon- 
troller. 

3.3.10.2 BIT 2 RESET 

Writing a 1 to this bit resets the WD42C22C. The 
RESET output is asserted and remains asserted 
until this bit is written back to 0. This bit must 
be on for a minimum of 5.0 psec. If reset has 
been disabled by the local microcontroller then 
writing a ’ 1’ to t his bit only resets the 
WD42C22C. RESET is no t assert ed in this case. 
The WD42C22C asserts MCINT and the local 
microcontroller is responsible for resetting the 
drive controller board logic. 

3.3.10.3 BIT 1 INTERRUPT ENABLE 

When IEN = 0, then the INTRQ output to the 
host is enabled. When IEN = 1, then the 
INTRQ output to the host is disabled. Disabling 
interrupts does NOT reset an existing interrupt but 
inhibits all further interrupts. Any interrupts pend- 
ing when this bit is set causes the INTRQ output 
to be asserted. A system master reset does NOT 
affect the IEN bit but resets any existing interrupt. 
The internal power qualified reset sets IEN to 0. 
When interrupts are disabled, then the INTRQ pin 
is tri-stated. 

3.3.11 DIGITAL INPUT REGISTER 

(HA9, HA2 THRU HA0 = F, READ) 

The digital input regi ster is used b y the host to 
determine the state of WRITE GATE and the drive 
selects and head selects. Bit 5 is written by the 
local microcontroller when HS3EN (bit 3 of the 
fixed disk register) is set to zero. Bit 5 comes from 
bit 3 of the host SDH register with HS3EN set to 
one. Bits 0 through bit 4 also come from the host 
SDH register. When this register is read by the 


host, then HD7 (pin 82) is tri-stated. It is coded as 
follows: 


Bit 

7 

6 

5 4 

3 

2 1 

0 

X 

WG 

HS3/ HS2 
RWC 

HS1 

HS0 DS2 

DS1 


3.3.1 1.1 BIT 6 WRITE GATE ON 

This bit reflects the state of the WG output 
pin. 

3.3.11.2 BIT 5 HEAD SELECT 3/ 

REDUCE WRITE CURRENT 

This bit reflects the stat e of the HS3/RWC 
drive control output. The R WC b it is written 
by the local microcontroller. HS3 comes from 
the SDH register bit 3. 

3.3.11.3 BIT 4, BIT 3, AND BIT 2 HEAD 
SELECTS 

Thes e bits reflect the states of the HS2, HS1, 
HS0, and drive control outputs respectively. 
These bits are controlled by SDH register bits 2 
through 0 respectively. 

3.3.11.4 BIT 1 AND BIT 0 DRIVE SELECTS 

These bits indicate which drive is currently 
being selected by the host. They are controlled 
by the SDH register bit 4. 
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A 

A 

A 

A 

A 

A 

A 

A 

READ PORT 

WRITE PORT 

D 

D 

D 

D 

D 

D 

D 

D 



7 

6 

5 

4 

3 

2 

1 

0 



DISK CONTROLLER TASK FILE 


0 

0 

0 

X 

X 

X 

X 

X 

BUS TRISTATE 

NOT USED 

0 

0 

1 

0 

0 

0 

0 

0 

INVALID 

INVALID 

0 

0 

1 

0 

0 

0 

0 

1 

Error Register 

PLO Length 

0 

0 

1 

0 

0 

0 

1 

0 

Sector Count 

Sector Count 

0 

0 

1 

0 

0 

0 

1 

1 

Sector Number 

Sector Number 

0 

0 

1 

0 

0 

1 

0 

0 

Cylinder Number Low 

Cylinder Number Low 

0 

0 

1 

0 

0 

1 

0 

1 

Cylinder Number High 

Cylinder Number High 

0 

0 

1 

0 

0 

1 

1 

0 

SDH 

SDH 

0 

0 

1 

0 

0 

1 

1 

1 

Status Register 

Command Register 

XT 










0 

0 

1 

0 

1 

T 

0 

1 

Hardware Status 

Hardware Status 

0 

0 

1 

0 

1 

1 

1 

0 

NOT USED 

Drive Configuration 

BUFFER MANAGER 



0 

0 

1 

1 

0 

0 

0 

0 

Host Buffer Pointer Low 

Host Buffer Pointer Low 

0 

0 

1 

1 

0 

0 

0 

1 

Host Buffer Pointer High 

Host Buffer Pointer High 

0 

0 

1 

1 

0 

0 

1 

0 

Host Transfer Count Low 

Host Transfer Count Low 

0 

0 

1 

1 

0 

0 

1 

1 

Host Transfer Count High 

Host Transfer Count High 

0 

0 

1 

1 

0 

1 

0 

0 

Disk Buffer Pointer Low 

Disk Buffer Pointer Low 

0 

0 

1 

1 

0 

1 

0 

1 

Disk Buffer Pointer High 

Disk Buffer Pointer High 

0 

0 

1 

1 

0 

1 

1 

0 

Microcontroller RAM Access 

Microcontroller RAM Access 

0 

0 

1 

1 

0 

1 

1 

1 

Buffer Status 

Buffer Control 


TABLE 11. LOCAL MICROCONTROLLER REGISTER MAP 


3.4 SLAVE HOST INTERFACE 

In slave mode, the WD42C22C host interface can 
be hooked up to a peripheral device such as the 
WD33C93 (SBIC). The microcontroller reads and 
writes the peripheral device through the 
WD42C22C using the ports as follows: 


AAAAAAAAA READ WRITE 

BDDDDDDDD PORT PORT 

S 7 6 5 4 3 2 1 0 

Y 

X 0 1 0 0 1 0 0 0 Bustri- Slave 

state address 

port for 
reads 

X 0 1 0 0 1 0 1 0 Bustri- Slave 

state address 

port for 
writes 

X 0 1 0 0 1 0 0 1 Slave Slave 

read write 

data data 
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A 

A 

A 

A 

A 

A 

A 

A 

A 

READ PORT 

WRITE PORT 

B 

D 

D 

D 

D 

D 

D 

D 

D 



S 

Y 

7 

6 

5 

4 

3 

2 

1 

0 



MISC. 










X 

0 

0 

1 

1 

1 

0 

0 

0 

Interface Status 

Interface Control 

X 

0 

0 

1 

1 

1 

0 

0 

1 

Configuration Status Low 

NOT USED 

X 

0 

0 

1 

1 

1 

0 

1 

0 

Configuration Status High NOT USED 

X 

0 

0 

1 

1 

1 

0 

1 

1 

Drive Interface Status 

Drive Interface Control 

X 

0 

0 

1 

1 

1 

1 

0 

0 

Alternate Sector Number 

NOT USED 

AT INTERFACE 






X 

0 

0 

1 

0 

1 

0 

1 

0 

AT Control Register 

AT Control Register 

X 

0 

0 

1 

1 

1 

1 

0 

1 

Drive 0 Status 

Drive 0 Status 

X 

0 

0 

1 

1 

1 

1 

1 

0 

Drive 1 Status 

Drive 1 Status 

X 

0 

0 

1 

1 

1 

1 

1 

1 

Fixed Disk Register 

Digital Input Register 

AT INTERFACE (TASK FILE COPY) 


1 

0 

1 

0 

0 

0 

0 

0 

1 

Write Precomp Cylinder 

Error Register 

1 

0 

1 

0 

0 

0 

0 

1 

0 

Sector Count 

Sector Count 

1 

0 

1 

0 

0 

0 

0 

1 

1 

Sector Number 

Sector Number 

1 

0 

1 

0 

0 

0 

1 

0 

0 

Cylinder Number Low 

Cylinder Number Low 

1 

0 

1 

0 

0 

0 

1 

0 

1 

Cylinder Number High 

Cylinder Number High 

1 

0 

1 

0 

0 

0 

1 

1 

0 

SDH 

SDH 

1 

0 

1 

0 

0 

0 

1 

1 

1 

Command Register 
(from Host) 

NOT USED 

SLAVE HOST 







0 

0 

1 

0 

0 

0 

X 

X 

X 

INVALID 

INVALID 

X 

0 

1 

0 

0 

1 

0 

0 

0 

INVALID 

Slave Address Port for reads 

X 

0 

1 

0 

0 

1 

0 

0 

1 

Slave Read Data 

Slave Write Data 

X 

0 

1 

0 

0 

1 

0 

1 

0 

INVALID 

Slave Address Port for writes 

X 

0 

1 

0 

0 

1 

X 

X 

X 

INVALID 

NOT USED 

X 

0 

1 

0 

1 

X 

X 

X 

X 

INVALID 

NOT USED 

X 

0 

1 

1 

X 

X 

X 

X 

X 

BUS TRISTATE 

NOT USED 

X 

1 

X 

X 

X 

X 

X 

X 

X 

BUS TRISTATE 

NOT USED 


TABLE 11. LOCAL MICROCONTROLLER REGISTER MAP (CONT’D) 


The slave peripheral connects to the WD42C22C the register contents are read or written. This ad- 
using an ALE type interface. Register reads and dress must always be written before each 
writes are always 8-bit. The procedure to read or register access even when consecutively access- 

write a slave peripheral register is to first write the ing the same register two or more times, 

register number to the slave address port before 
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Data transfers between the peripheral device and 
the WD42C22C are WD-bus mode and c an be 
either 8-bit or 16-bit and is controlled by the HI 6/8 
bit (bit 1 of the auxilliary buffer control register). 
The slave mode is enabled by the HSMB bit (bit 6 
of the auxilliary buffer control register). 

3.5 LOCAL MICROCONTROLLER 
INTERFACE ORGANIZATION 

The local microcontroller controls the host inter- 
face mode (AT or XT) and controls the buffer 
manager and the drive controller. The local 
microcontroller is usually in a sleep state until it is 
told to do something by the as sertion of the 
MCINT output. In the XT mode, MCINT is as- 
serted when t he controller is selected. In the AT 
mode, MCINT is asserted when the host writes to 
the co mmand register. In slave host mode, 
MCINT is asserted when the sl ave pe ripheral 
device asserts its INTRQ signal. MCINT is also 
asserted at the end of each host or disk transfer 
regardless of the interface mode. 

The local microcontroller can have either the 
Intel-type (8051) or the Motorola-type (68HC11) 
interface. The WD42C22C has a built-in MO- 
torola-inTEL (MOTEL) circuit which can sense the 
processor interface type and can therefore be 
directly interfaced to either type processor. 

Table 11 lists the register map for the local 
microcontroller. 

3.6 DISK CONTROLLER TASK FILE 
(AD7 THRU ADO = 20 THRU 27) 

3.6.1 ERROR REGISTER (AD7 THRU ADO = 
21, READ) 

The error register reads only and contains the 
specific error status pertaining to a command. 
The meaning of the status register bits are as 
follows: 


Bit 

7 

6 5 

4 

3 

2 

1 0 

BB 

CRC/ RIDF 
ECC 

IDNF 

0 

AC 

0 DMNF 


3.6.1. 1 BIT 7 BAD BLOCK 

A bad block address mark has been detected 
when trying to read or write that sector. The data 
field is not be read or written. 

3.6.1 .2 BIT 6 CRC/ECC DATA FIELD ERROR 

A CRC error in the data field has been detected 
when in CRC mode. In ECC mode, data errors 
were detected in the data. 

3.6.1 .3 BIT 5 RELOCATION ID FOUND 

This bit is set if a relocation ID is found after 
detecting the bad block mark in the desired 
sector’s ID field. This bit is only valid if the R 
option is used in the set parameter command. 

3.6.1 .4 BIT 4 ID NOT FOUND 

Occurs when cylinder, head, sector, size para- 
meters with a correct ID field CRC cannot be 
found. For a scan ID command, this bit is set after 
10 index pulses if the retry disable bit is not set. 
Otherwise, IDNF is set after 2 index pulse if no ID 
was found. For read and write sector commands 
with the retry disable bit set, this bit indicates that 
after 10 index pulses, auto-scan ID and auto- 
seek, and 10 more index pulses, no matching ID 
field was found. If the retry disable bit is set and 
no matching ID field was found after 2 index pul- 
ses, then no auto-scan or auto-seek is performed. 

3.6.1 .5 BIT 3 RESERVED 

Not used, forced to zero. 

3.6.1 .6 BIT 2 ABORTED COMMAND 

Set if command was started and one of the follow- 
ing conditions occurred: 

• 1 . Drive not ready 

• 2. Write fault 

• 3. Illegal command code. 

3.6.1 .7 BIT 1 RESERVED 

Not used in WD42C22C, forced to zero. 

3.6.1 .8 BIT 0 DATA ADDRESS MARK NOT 
FOUND 

Set if the first two bytes of the data field following 
an ID match are not A1 F8. This condition is 
checked for read sector commands only. 
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3.6.2 PLO LENGTH REGISTER 
(AD7 THRU ADO = 21 , WRITE) 

This register is used for two purposes: 

• 1 . To determine the length of the Data PLO 
sync field during write commands and to deter- 
mine the length of the ID PLO sync field dur- 
ing format commands. The contents of this 
register regulates the PLO field size in all data 
coding modes. 

• 2. To load a value in the internal GAP register. 
During the load parameter block command, 
the contents of the lower six bits of the PLO 
length register are transferred to the internal 
GAP register. In hard sector NRZ (ESDI) 
mode, this internal GAP register is used to 
control the delay between the INDEX or SEC- 
TOR pulse and the leading edge of READ 
GATE. In hard sector MFM or RLL mode, this 
internal GAP register is used to control the 
delay between the INDEX or SECTOR pulse 
and the falling edge of the internally generated 
DRUN signal. In hard sector MFM or RLL 
mode, RG is asserted 2 byte times after 
INDEX or SECTOR. This GAP register is al- 
tered by loading the desired GAP register 
value into the PLO length register and then is- 
suing a load parameter block command. 

3.6.3 SECTOR COUNT (AD7 THRU ADO = 22, 
READ/WRITE) 


Bit 

7 6 5 4 3 2 1 ~0 

NUMBER OF SECTORS/GAP VALUE 
SECTOR WITH BAD BLOCK 


This register is used for three purposes: 

• 1 . The sector count register is used in read 
sector, write sector, and format commands to 
implement multiple sector handling with one 
command. A value of 1 indicates a single sec- 
tor transfer, a value of 2 indicates a 2 sector 
transfer, and so forth. A value of 0 indicates a 
256 sector transfer. Sector count decrements 
and sector number increments after each sec- 
tor transfer to or from the buffer. 

• 2. To load a value into the internal gap value 
register. During the load parameter block com- 
mand the contents of this register are trans- 
ferred into an internal gap value register. This 


gap value register specifies the data byte writ- 
ten into the gaps during format commands. 

• 3. To specify to the microcontroller the sector 
number where a bad block bit was detected if 
relocation ID searches are enabled. If the R 
option is set in a set parameter command, 
then during read and write commands if a bad 
block is detected, the WD42C22C searches 
for a special ID field containing relocation infor- 
mation. When the command terminates due to 
a bad block, then the sector number of the sec- 
tor with the bad block is returned to the micro- 
controller in this register. This is true whether 
or not the relocation information is detected. 

3.6.4 SECTOR NUMBER 

(AD7 THRU ADO = 23, READ/WRITE) 


Bit 

7 6 5 4 3 2 1 ~0 

SECTOR NUMBER / GAP SIZE 


The sector number register has three uses: 

• 1 . To hold the number of the desired sector for 
read and write commands. The sector number 
can range from 0 to 255. 

• 2. To control the Gap 1 and Gap 3 sizes 
during format commands. The sector number 
holds the number of gap bytes minus three for 
format (number of gap bytes minus six for 
NRZ mode). 

• 3. To load a value into the internal pad value 
register. During the load parameter block com- 
mand, the contents of this register are trans- 
ferred into an internal pad value register. This 
pad value register specifies the data byte writ- 
ten into the ID and DATA pads during format 
and write commands. 

3.6.5 CYLINDER NUMBER REGISTERS 
(CYLINDER NUMBER LOW: 

AD7 THRU ADO = 24, READ WRITE 
CYLINDER NUMBER HIGH: 

AD7 THRU ADO = 25, READ/WRITE) 

This register has two functions: 

• 1 . To specify the cylinder number for read, 
write, and format commands. The cylinder 
number may range in value from 0 to 2047. 

• 2. The cylinder number register is used during 
a load parameter block command to specify 
the desired sector size if a non-standard sec- 
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tor size is desired and to specify the offset for 
a write ID command. To load the internal sec- 
tor size register, write in the desired sector 
size into the cylinder registers. Next, issue a 
load parameter block command. Set U=1 to 
enable the programmable sector size or 
programmable write ID offset. 

3.6.6 CYLINDER NUMBER REGISTERS 
(CYLINDER NUMBER LOW: 

AD7 THRU ADO = 24, READ/WRITE 
CYLINDER NUMBER HIGH: 

AD7 THRU ADO = 25, READ/WRITE) 

Cylinder number low register holds the 8 least 
significant bits of the desired cylinder number or 
the 8 least significant bits of the desired sector 
size. 

Cylinder number high register holds the three 
most significant bits (bits 0 through 2) of the 
desired cylinder number or the three most sig- 
nificant bits of the desired sector size. Bits three 
through seven of the cylinder number high 
register are not used and must be set to zero. 

3.6.7 SDH REGISTER (AD7 THRU ADO = 26, 
READ/WRITE) 

This register is used to specify the desired drive 
and head numbers and to specify CRC or ECC 
mode. There are two SDH modes available, three 
or four bit head number. Three bit head mode is 
the default after a master reset. Setting the H bit 
in the set parameter command engages the four 
bit head mode. 


3.6.7.1 SDH REGISTER, THREE-BIT HEAD 
NUMBER 


Bit 

7 6 

5 

4 

3 

2 1 0 

CRC/ SSI 
ECC 

sso 

0 

0 

Head # 


3.6.7.2 SDH REGISTER, FOUR-BIT HEAD 
NUMBER 


Bit 

7 

6 

5 

4 

3 2 1 

0 

CRC/ 

ECC 

SSI 

SSO 

0 

Head # 



3.6.7.3 BIT 7 ECC/CRC SELECT 

This bit is set for data field ECC mode. It is reset 
for data field CRC mode. In RLL mode, this bit is 
ignored. RLL mode always uses 7-byte ECC. The 
CRC/ECC flag bit is not written on the disk at 
format time. The bad block flag is written on the 
disk in its place. 

3.6.7.4 BIT 6 AND BIT 5 SECTOR SIZE 

Bits 6 and 5 contain sector size bits. These bits 
are written on the disk at format time. These bits 
should be 0 if programmable sector size is used. 
These bits are reserved for special flags in 
programmable sector size mode. The possible 
sector sizes and their selection codes are as fol- 
lows: 


SSI 

sso 

Sector Size 

0 

0 

256 byte data field 

0 

1 

512 byte data field 

1 

0 

1024 byte data field 

1 

1 

1 28 byte data field 


The sector sizes can be optionally specified to 
be any value between 100 and 2048 bytes by 
using the load parameter block command. The 
user is responsible for validating the effectiveness 
of the ECC for sector sizes over 1 056 bytes. 

3.6.7.5 BIT 4 AND BIT 3 RESERVED 

BIT 4 DRIVE NUMBER RESERVED 

Reserved. Set to 0. 

3.6.7.6 BIT 2, BIT 1, AND BIT 0 
THREE BIT HEAD NUMBER 
BIT 3, BIT 2, BIT 1 , AND BIT 0 
FOUR BIT HEAD NUMBER 

Bits 2, 1, and 0 specify the desired head 
number in the three bit mode. Bits 3, 2, 1, and 0 
specify the desired head number in four bit mode. 
The local microcontroller is responsible for 
outputting these bits to the drive. 

NOTE 

These bits are written on the disk at format 
time. The SDH byte written in the ID field during 
a format command is NOT the same as the SDH 
register. The SDH format byte is shown 
below: 


38 
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3.6.7.7 SDH ID FIELD FORMAT BYTE 


(THREE BIT HEAD MODE) 


Bit 

7 

6 5 4 3 2 1 

0 

Bad 

Block 

SSI SSO 0 0 Head # 


3.6.7.8 

SDH ID FIELD FORMAT BYTE 
(FOUR BIT HEAD MODE) 


Bit 

7 

6 5 4 3 2 1 

0 

Bad 

Block 

SSI SSO 0 Head # 



3.6.8 STATUS REGISTER (AD7 THRU 
ADO = 27, READ) 

The status register is read only and reflects the 
status of the controller as well as the status of 
certain drive control lines. If command in progress 
(bit 1) is set then no other register reads are valid 
and none of the other register bits are valid. The 
status register contents are returned for any read 
and all writes are disabled. The description of the 
status register bits follows: 


Bit 

7 

6 

5 

4 3 

2 

1 

0 

0 

RDY 

WF 

1 0 

0 

0 

ERR 


3.6.8.1 BIT 7 ALWAYS 0 


This bit is always zero when the microcontroller 
has access to this status register. 

3.6.8.2 BIT 6 DRIVE READY 

This bit reflects the status of the DRDY. Any com- 
mand aborts if DRDY is low. 

3.6.8.3 BIT 5 WRITE FAULT 

This bit reflects the state of the WF pin. Any com- 
mand aborts if WF is high. 

3.6.8.4 BIT 4 ALWAYS 1 

This bit reflects the state of the SC input to the 
drive controller. This signal is internally tied to 
Vdd- 


3. 6. 8. 5 BIT 3 ALWAYS 0 

This bit reflects the state of the BDRQ signal that 
goes between the drive controller and the buffer 
manager. It is always zero when the 
microcontroller has access to this status register. 

3. 6.8.6 BIT 2 NOT USED 

Forced to 0 

3. 6.8.7 BIT 1 ALWAYS 0 

This bit reflects the state of the command in 
progress signal in the drive controller. It is always 
zero when the microcontroller has access to this 
status register. 

3.6.8.8 BIT 0 ERROR 

This bit indicates that a non-recoverable error has 
occurred. The error register describes the error 
condition when this bit is asserted. 

Drive ready and write fault bits reflect the state of 
their associated input pins. The states of these 
status register bits are latched at the end of the 
command and are unlatched after the first status 
register read. Reading the status register results 
in the disk controller interrupt being reset. 

3.6.9 COMMAND REGISTER 

(AD7 THRU ADO = 27, WRITE) 

The command to be executed is written into this 
register. Writing this register sets the internal 
BUSY and CIP signals and causes the controller 
to start executing the desired command. Writing 
this register resets the disk controller interrupt 
(DCI bit in the interface status register). 

3.7 XT INTERFACE PORTS 

3.7.1 XT HOST HARDWARE STATUS 

(AD7 THRU ADO = 2D, READ/WRITE) 

Bits 7, 6, 2, and 1 of this register are written by 
the local microcontroller and read by the host. The 
other bits reflect the state of certain hardware sig- 
nals. This register is readable and valid in all host 
modes. 


Bit 

7 

6 5 

4 

3 2 

1 

0 

1 

1 IRQ 

DRQ 

XBSY C/D 

I/O 

REQ 


2S 
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3.7.1 .1 BITS 6 AND 7 UNDEFINED 

These bits are currently undefined in the XT 
protocol and read as 1 . 

3.7.1 .2 BIT 5 INTERRUPT REQUEST 

This bit reflects the state of the INTRQ output. 
This bit can NOT be written by the microcontrol- 
ler. 

3.7.1 .3 BIT 4 DMA REQUEST 

This bit reflects the state of the DREQ output. 
This bit can NOT be written by the microcontroller. 

3.7.1 .4 BIT 3 XT BUSY 

This bit reflects the state of the internal XT 
BUSY flipflop. This bit is set by during a reset and 
is set when the WD42C22C is selected in XT 
mode. This bit can NOT be written by the micro- 
controller. 


3.7.1 .5 BIT 2 COMMAND / DATA 

This bit tells the host which type of transfer is 
ex£ected at the read data and write data ports. 
C/D = 1 indicates that a_command or status trans- 
fer is expected and C/D = 0 indicates that a data 
transfer is expected. This bit is written by the 
microcontroller. 


3.7.1 .6 BIT 1 INPUT / OUTPUT 

This bit tells the host the direction of transfer for 
the two data ports. I/O = 1 indicates an input 
(read) by the host and I/O = 0 indicates 
an output (write) by the host. This bit is written by 
the microcontroller. 

3.7.1 .7 BIT 0 REQUEST 

This bit indicates the state of the internal host 
transfer enable. This bit is active when the buffer 
manager is transferring data between the RAM 
and the host. This bit can NOT be written by the 
microcontroller. This bit is identical to the DRQ in 
the drive zero status and drive one status 
registers used in AT mode. 

3.7.2 HOST DRIVE CONFIGURATION 
(AD7 THRU ADO = 2E, WRITE) 

This register is used to write the drive configura- 
tion information that is read by the host. 


3.7.3 BUFFER MANAGER REGISTERS 
(AD7 THRU ADO = 30 THRU 37) 
HOST BUFFER POINTER LOW 
(AD7 THRU ADO = 30, READ/WRITE) 
HOST BUFFER POINTER HIGH 
(AD7 THRU ADO = 31 , READ/WRITE) 


Bit 

7 6 5 4 3 2 1 ~0 

LEAST SIGNIFICANT BYTE OF HOST 
BUFFER POINTER 


Bit 

7 6 5 4 3 2 1 ~0 

0 MOST SIGNIFICANT BITS OF HOST 
BUFFER POINTER 


The host buffer pointer low register contains the 
least significant byte of the host buffer pointer. 
The host buffer pointer high register contains the 
seven most significant bits of the host buffer 
pointer. The host buffer pointer is used as the 
base address for the internal host buffer counter. 
The contents of the host buffer pointer registers 
are transferred to the host buffer pointer counter 
under the control of the buffer control register. 

When the AHBP bit is set in the control register, 
then the pointer register is transferred to the 
pointer counter when the transfer counter reaches 
zero. If the transfer count is already zero, then the 
transfer occurs immediately. This allows a pend- 
ing transfer to be queued behind the current 
transfer. When the pointer is transferred to the 
counter, the AHBP buffer status bit resets. 

3.7.4 HOST TRANSFER COUNT LOW 

(AD7 THRU ADO = 32, READ/WRITE 
HOST TRANSFER COUNT HIGH 
(AD7 THRU ADO = 33, READ/WRITE) 

The host transfer count low register contains the 
least significant byte of the host transfer count. 
The host transfer count high register contains the 
most significant bits of the host transfer count. 
The transfer count controls the number of bytes 
that are to be transferred on the host interface. 
The transfer count register is transferred to the 
internal transfer counter at the same time that the 
host buffer pointer register is transferred to the 
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host buffer pointer counter. The transfer counter is 
12 bits long which gives a maximum transfer 
count of 4095 bytes. 


Bit 

7 6 5 4 3 2 1 ~~0 

LEAST SIGNIFICANT BYTE OF HOST 
TRANSFER COUNT 


Bit 

7 

6 

5 

4 

3 2 10 

0 

0 

0 

0 

MS BITS OF 

HOST TRANSFER 
COUNT 


3.7.5 DISK BUFFER POINTER LOW 

(AD7 THRU ADO = 34, READ/WRITE) 
DISK BUFFER POINTER HIGH 
(AD7 THRU ADO = 35, READ/WRITE) 

The disk pointer low register contains the least 
significant byte of the disk buffer pointer. The disk 
pointer high register contains the seven most sig- 
nificant bits of the disk buffer pointer. The disk 
buffer pointer is used as the base address for the 
internal disk buffer counter. The contents of the 
disk buffer pointer registers are transferred to the 
disk buffer pointer counter under the control of the 
buffer control register. When the ADBP bit is set in 
the control register, then the pointer is transferred 
to the counter when the drive controller sets DRQI 
to 1 (bit 1) in the interface status register (38i6). 
This allows a pending transfer to be queued be- 
hind the current transfer. When the pointer 
register is transferred to the counter, the ADBP bit 
in the buffer status resets. If ADBP=0 when the 
drive controller sets DRQI to 1, then the drive 
controller stops transferring data to the buffer and 
discontinues the command until ADBP sets. 


Bit 


7 6 5 4 3 2 1 

0 

LEAST SIGNIFICANT BYTE OF 

DISK BUFFER POINTER 



Bit 

7 

6 5 4 3 2 1 

0 

0 

MOST SIGNIFICANT BYTE OF 



DISK BUFFER POINTER 



3.7.6 MICROCONTROLLER RAM ACCESS 

PORT (AD7 THRU ADO = 36, 

READ/WRITE) 

This port is used by the local microcontroller to 
access the buffer RAM. Accesses to this port go 
through the drive controller’s FIFO. These acces- 
ses are enabled by the MAC bit in the drive inter- 
face control register. The DRWB bit in the buffer 
manager control register controls the direction of 
the accesses. 

3.7.7 BUFFER CONTROL REGISTER 
(AD7 THRU ADO = 37, WRITE) 

This register is used to control the buffer 
manager. 

Bit 

7 6 5 4 

AT/XT RDCFG RXC AHBP 
3 2 10 

HRWB DRWB BDEN ADBP 


3.7.7.1 BIT 7 AT / XT INTERFACE CONTROL 

This bit, along with HSMB, in the auxilliary 
buffer control^ register, controls the host interface 
type. If AT/XT = 0, then the interface is XT type if 
HSMB = 0. If AT/XT = 1, then the interface is AT 
type if HSMB = 0. This bit has no meaning if 
HSMB = 1. The RESET input and the host soft 
reset does not affect this bit. 

3.7.7.2 BIT 6 READ CONFIGURATION 

When this bit is set, all buffer address outputs 
are placed in a medium impedence state with 
each buffer address pin having a 180 [iA current 
source pulldown. The buffer manager should be 
idle when this mode is enabled. This mode is 
used to read configuration switch information. The 
microcontroller should wait 100 psec after setting 
this bit before readi ng the c onfiguration registers. 
This bit resets when RESET is asserted. 

3.7.7.3 BIT 5 RESET TRANSFER COUNTER 

When this bit is set, the internal transfer counter 
and the host FIFO pointers reset. This bit resets 
after the transfer counter and FIFO reset. 
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3.7.T.4 BIT 4 ARM HOST BUFFER POINTER 

Writing a 1 to this bit, sets an internal latch. Writ- 
ing a 0 to this bit has no effect. When this bit is 
set, then when the internal transfer counter 
reaches zero the host buffer pointer is transferred 
to the internal host buffer counter and the host 
transfer count is transferred to the internal transfer 
counter. This bit is reset by the WD42C22C after 
the host pointer and cou nt regist ers are trans- 
ferred. This bit resets when RESET is asserted. 


3.7.7.5 BIT 3 HOST READ / WRITE 

This bit controls the direction of the host data 
transfers. It is used internally to control the direc- 
tion of the FIFO. When HRWB = 0, then the host 
writes to the WD42C22C. When HRWB = 1, then 
the host reads from the WD42C22C. 


3.7.7.6 BIT 2 DISK READ / WRITE 

This bit controls the direction of the disk or local 
microcontroller data transfers. It is used internally 
to control the direction of the disk FIFO. When 
DRWB = 0, then the disk controller or local 
microcontroller writes to the buffer RAM. When 
DRWB = 1, then the disk controller or local 
microcontroller reads from the buffer RAM. When 
the microcontroller accesses the buffer RAM, then 
this bit should be written before the ADBP bit is 
set. 

3.7.7.7 BIT 1 BURST DMA ENABLE 

When BDEN = 1 and HDMA = 1 in the auxiliary 
buffer control register, then burst DMA transfers 
are enabled on the host interface. 

3.7.7 .8 BIT 0 ARM DISK BUFFER POINTER 

Writing a 1 to this bit, sets an internal latch. Writ- 
ing a 0 to this bit has no effect. When this bit is 
set, then the disk buffer pointer is transferred to 
the internal disk buffer counter when the drive 
controller sets the BDRQ interrupt. This bit also 
enables the disk controller to continue to the next 
sector. This bit is reset by the WD42C22C after 
the pointer registers have been transferred. 
When the disk controller port is used by the local 
microcontroller to access the buffer RAM, then 
setting this bit resets the disk FIFO pointers and 
the next byte read or written by the microcontroller 


will be at the new address loaded into the disk 
buffer pointer. 

3.7.8 BUFFER STATUS REGISTER 
(AD7 THRU ADO = 37, READ) 

This register reflects the status of the buffer 
manager logic. 


Bit 

7 

6 

5 

4 

AT/XT 

RDCFG 

RXC 

AHBP 

3 

2 

1 

0 

HRWB 

DRWB 

BDEN 

ADBP 


3.7.8.1 BIT 7 AT / XT INTERFACE MODE 

This status bit reflects the state of the AT/XT con- 
trol bit defined above. 


3.7.8.2 BIT 6 READ CONFIGURATION 

This bit reflects the state of the read configuration 
control bit defined in the buffer manager control 
register. 

3.7.8.3 BIT 5 RESET TRANSFER COUNTER 

This bit reflects the state of the RXC control bit 
defined in the buffer control register. 

3.7.8.4 BIT 4 HOST BUFFER POINTER 
ARMED 

This bit reflects the state of the AH BP control bit 
defined in the buffer control register. 

3.7.8.5 BIT 3 HOST READ / WRITE 

This bit reflects the state of the HRWB control bit 
defined in the buffer control register. 

3.7.8.6 BIT 2 DISK READ / WRITE 

This bit reflects the state of the DRWB control bit 
defined in the buffer control register. 

3.7.8.7 BIT 1 BURST DMA ENABLE 

This bit reflects the state of the BDEN control bit 
defined in the buffer control register. 

3.7.8.8 BIT 0 DISK BUFFER POINTER ARMED 

This bit reflects the state of the ADBP control bit 
defined in the buffer control register. 
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3.7.9 AUXILIARY BUFFER CONTROL 
REGISTER (AD7 THRU ADO = 2F, 
WRITE) 

This register is used for additional control of the 
buffer manager and host interface. 


Bit 

7 

6 

5 

4 

HDMA 

HSMB 

BCNT 

IDD 

3 

2 

1 

0 

DSEL 

X 

HI 6/8 

SCKS 


3.7.9.1 BIT 7 HOST DMA 

This bit controls the host data transfers to/from 
the buffer RAM. If HDMA = 1, then the data is 
transferred to the host via DMA regardless of the 
host interface selected. If HDMA = 0, the default, 
then data is transferred via programmed I/O. 

3.7.9.2 BIT 6 HOST SLAVE / MASTER 

When HSMB = 0, the default, then the host is a 
master which drives the WD42C22C in either XT 
or AT type interface. When HSMB = 1, then the 
host is a slave device which is controlled by the 
local microcontroller. The slave device can be 
addressed in either ALE or indirect mode. The 
SBIC is an example of a device which can be 
connected to the WD42C22C. The ALE mode 
supports up to 32 registers in the slave device. 
Data transfers occur via WD-BUS mode if HDMA 
= 1 and is an 8-bit transfer if HI 6/8 = 0 and a 
16-bit transfer if HI 6/8 = 1. This bit resets upon 
power-up but not affected by RESET. 

3.7.9.3 BIT 5 BURST CONTINUOUS 

This bit, along with the HDMA bit, and the BDEN 
bit in the buffer control register control the burst- 
ing of data during DMA transfers. If BCNT = 
1, HDMA = 1, and BDEN = 1, then the 
WD42C22C DMAs data continuously as long as 
the FIFOs can keep up. If BCNT = 0, HDMA = 1, 
and BDEN = 1, then the WD42C22C DMAs data 
in 8-byte or 16-byte maximum length bursts, for 8 
and 16 bit host data bus width, respectively. 

3.7.9.4 BIT 4 INTELLIGENT DRIVE DECODE 

When IDD = 1, then the controller is assumed to 
be on an i ntelligen t drive. The HDO-15, INTRQ, 
and DREQ/IOCS16 outputs are always tri-stated if 




the drive is not selected. If IDD = 0, the default, 
then the outputs are controlled normally. This b it 
resets upon power up but not affected by RESET. 

3.7.9.5 BIT 3 DRIVE SELECT 

This bit is used when IDD = 1 to control drive 
selection. If AT/XT =1, then the drive is con- 
sidered selected when SDH register bit 4 equals 
DSEL. If AT/XT = 0, then the drive is considered 
selected if DSEL = 1 and not selected if DSEL = 
0. This bit resets upon power-up but not affected 
by RESET. 

3.7.9.6 BIT 1 HOST 1 6 / 8 BIT 

This bit controls the width of the data transfers on 
the host side. If HI 6/8 = 0, then the host data 
transfers are 8-bit. If H16/8 = 1, the host data 
transfers are 1 6-bit . This bi t resets upon power up 
but not affected by RESET. 

3.7.9.7 BIT 0 SYNCHRONOUS CLOCK 
SWITCH 

This bit is used to control the clocking of the drive 
controller so that ESDI drives can be changed or 
data rates can be changed without the need for 
external clock deglitching. When SCKS =1 , the 
default, then the WD42C22C synchronously 
switches the drive controller to the internal buffer 
clock (BCLK). When SCKS = 0, the WD42C22C 
switches the drive controller back to WCLK. The 
switch occurs only if both clocks are present. The 
CKSRC status bit defined below in dicates 
whether or not the switch occured. When RESET 
is asserted, the buffer clock clocks the drive con- 
troller during the reset and SCKS is set. The 
microcontroller must switch the clock source to 
the WCLK input prior to issuing any commands to 
the drive controller. 

3.7.10 AUXILIARY BUFFER STATUS 
REGISTER (AD7 THRU ADO = 2F, READ) 

This register gives additional status of the buffer 
manager and host interface. 


Bit 

7 

6 

5 

4 

HDMA 

HSMB 

BCNT 

IDD 

3 

2 

1 

0 

DSEL 

CKSC 

HI 6/8 

SCKS 
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3.7.10.1 BIT 7 HOST DMA 

This bit reflects the state of the HDMA control bit 
defined in the auxilliary buffer control register. 

3.7.10.2 BIT 6 HOST SLAVE / MASTER 

This bit reflects the state of the HSMB control bit 
defined in the auxilliary buffer control register. 

3.7.10.3 BIT 5 BURST CONTINUOUS 

This bit reflects the state of the BCNT control 
bit defined in the auxilliary buffer control 
register. 

3.7.10.4 BIT 4 INTELLIGENT DRIVE DECODE 

This bit reflects the state of the IDD control bit 
defined in the auxilliary buffer control register. 

3.7.10.5 BIT 3 DRIVE SELECT 

This bit reflects the state of the DSEL control bit 
defined in the auxilliary buffer control register. 

3.7.10.6 BIT 2 CLOCK SOURCE 

This bit indicates the source of the drive controller 
clock. If CKSRC = 1 and SCKS = 1 , then the drive 
controller is being clocked by the buffer clock 
(BCLK). If CKSRC = 0 and SCKS = 0, then the 
drive controller is clocked by WCLK. If CKSRC = 
1 and SCKS = 0 or CKSRC = 0 and SCKS = 
1, then the clock source is undefined. CKSRC 
should not be checked until at least 10 clock 
periods after the SCKS has been written. The 
slower of BCLK and WCLK should be used in 
determining this delay. 

3.7.10.7 BIT 1 HOST 16/ 8 

This bit reflects the state of the HI 6/8 control bit 
defined in the auxilliary buffer control register. 

3.7.10.8 BIT 0 SYNCHRONOUS CLOCK 
SWITCH 

This bit reflects the state of the SCKS control bit 
defined in the auxilliary buffer control register. 

3.7.11 INTERFACE STATUS REGISTER 
(AD7 THRU ADO = 38, READ) 

This register is used to indicate the status of the 
WD42C22C. The bits are defined as follows: 


Bit 

7 

6 

5 

4 

MINT 

DCGI 

RSTI 

FEI 

3 

2 

1 

0 

DCI 

HPRI 

DRQI 

CWSI 


3.7.1 1 .1 BIT 7 MICROCONTROLLER 
INTERRUPT 

This bit is hig h if the MCINT output pin is as- 
serted. MCINT is the logical OR of seven sources: 

• 1 . A host SDH register write 

• 2. A host soft reset 

• 3. A FIFO error 

• 4. The disk controller interrupt signal 

• 5. The host transfer count interrupt flip-flop 

• 6. The disk controller BDRQ signal 

• 7. The command write/select interrupt flip-flop. 
If any of the bits 6 through 0 are set, then the 
MCINT bit is high. 

3.7.11.2 BIT 6 DRIVE CHANGE INTERRUPT 

This bit sets when the host writes a new value to 
the SDH register bit 4 when AT mode is selected. 

3.7.11 .3 BIT 5 SOFT RESET INTERRUPT 

This bit sets if the host initiates a soft reset. This 
bit resets by writing the proper bit in the interface 
control register. 

3.7.11 .4 BIT 4 FIFO ERROR INTERRUPT 

This bit sets if a FIFO overrun or underrun condi- 
tion occurs during host or disk transfers. It resets 
by writing the proper bit in the interface control 
register. 

3.7.11 .5 BIT 3 DISK CONTROLLER 
INTERRUPT 

This bit reflects the state of the disk controller 
interrupt signal. This interrupt occurs at the end of 
a command. This bit resets either when the disk 
controller status (port 27i6) is read or when the 
disk controller command (port 27i6) register is 
written. 

3.7.11.6 BIT 2 HOST POINTER READY 
INTERRUPT 

This bit reflects the state of the host transfer count 
interrupt flip-flop. This interrupt sets when the host 
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transfer counter reaches zero and the FIFO is 
empty if the host pointer is not armed. It is also 
set when the host pointer pipeline register is 
loaded into the host pointer counter. It resets by 
writing the proper bit in the interface control 
register. 

3.7.11.7 BIT 1 DISK BDRQ INTERRUPT 

This bit reflects the state of the disk controller 
BDRQ signal. It sets when the disk controller 
starts a transfer between the disk controller and 
the sector buffer. It resets by writing the proper bit 
in the interface control register. If ADBP = 0 (bit 0 
in the buffer control register, 37i6) when this bit 
first goes from 0 to 1, then DRQI and MCINT is 
not reset until after the microcontroller writes 
ADBP = 1. 

3.7.11.8 BIT 0 COMMAND WRITE / SELECT / 
SLAVE INTERRUPT 

This bit informs the local microcontroller that a 
command has been written if the WD42C22C is 
in AT mode, that the WD42C22C has been 

selected if it is in XT mode, or that the slave host 
device has issued an interrupt if in slave host 
mode. (Asserts INTRQ. A slave interrupt only trig- 
gers on rising edge of INTRQ.) This bit resets by 
writing the proper bit in the interface control 
register. 

3.7.12 INTERFACE CONTROL REGISTER 
(AD7 THRU ADO = 38, WRITE) 

This register is used to control various parts of the 
WD42C22C. The bits are defined as follows: 


Bit 

7 

6 

5 

4 

SIRQ 

RDCI 

RSRI 

RFEI 

3 

2 

1 

0 

RBSY 

RHRI 

RDQI 

RCWS 


3.7.12.1 BIT 7 SET INTERRUPT 

Writing a 1 to this bit generates a host interrupt if 
interrupts are enabled. 


3.7.12.2 BIT 6 RESET DRIVE CHANGE 
INTERRUPT 

Writing a 1 to this bit resets the host SDH write 
interrupt flip-flop. 

3.7.12.3 BIT 5 RESET SOFT RESET 
INTERRUPT 

Writing a 1 to this bit resets the soft reset interrupt 
flip-flop. In AT mode, the microcontroller must wait 
for the RST bit (2) in the FDR register (3Fi6> to be 
reset by the host before this interrupt can be 
reset. 

3.7.12.4 BIT 4 RESET FIFO ERROR 
INTERRUPT 

Writing a 1 to this bit resets the FIFO error inter- 
rupt flip-flop. 

3.7.12.5 BIT 3 RESET BUSY 

Writing a 1 to this bit resets the BSY status bit in 
the hardware status register if XT mode is 
selected or it resets the ABSY status bit in the 
host status register if AT mode is selected. In AT 
mode, this bit should only be set at the very end 
of a command after the last DRQ is asserted to 
the host. Internal logic handles ABSY during buff- 
er transfers to the host. 

3.7.12.6 BIT 2 RESET HOST POINTER READY 
INTERRUPT 

Writing a 1 to this bit resets the host pointer ready 
interrupt flip-flop. 

3.7.12.7 BIT 1 RESET DISK BDRQ INTERRUPT 

Writing a 1 to this bit resets the disk BDRQ inter- 
rupt flip-flop. 

3.7.12.8 BIT 0 RESET COMMAND WRITE / 
SELECT / SLAVE INTERRUPT 

Writing a 1 to this bit resets the command 
write/select/slave interrupt flip-flop. 

3.7.13 CONFIGURATION STATUS REGISTERS 
(LOW: AD7 THRU ADO = 39, READ 
HIGH: AD7 THRU ADO = 3A, READ) 

The configuration status registers are used to 
read the configuration jumpers on buffer address 
pins. When in read configuration mode, the buffer 
address lines have 300 \iA current source 
pulldowns enabled. If there is no external pullup 
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resistor on the buffer address line, then the state 
of the line is read as a 0. If a 13K external pullup 
resistor is connected to a buffer address line, 
then the state of the line is read as a 1. The 
configuration registers should not be read until 
100 jusec after enabling read configuration mode, 
to allow the buffer address line voltages to reach 
their proper value. Register contents are un- 
defined if not in read configuration mode. 


Configuration status low 

Bit 

7 6 5 4 3 2 1 0 

BA7 THRU BAO 

Configuration status high 

Bit 

7 6 5 4 3 2 1 0 

0 BA14THRU BA8 


3.7.14 DRIVE INTERFACE STATUS 
(AD7 THRU ADO = 3B, READ) 

This register gives status information for the drive 
controller. It is coded as follows: 


Bit 

7 

6 5 

4 

3 2 10 

RDC 

DRDY WF 

HDS 

MAC DROIPOLDSN 


3.7.14.1 BIT 7 RESET DRIVE CONTROLLER 

This bit reflects the state of the reset drive control- 
ler control bit defined in the drive interface control 
register. 

3.7.14.2 BIT 6 DRIVE READY 

This bit is set if the DRDY input is asserted by the 
drive. It can always be read by the local 
microcontroller regardless of the state of disk con- 
troller busy. 

3.7.14.3 BIT 5 WRITE FAULT 

This bit is set if the WF input is asserted by the 
drive. It is always valid. 

3.7.1 4.4 BIT 4 HOST DRIVE SELECT 

This bit reflects the state of bit 4 of register 46i6, 
the host copy of the SDH register. It is used by the 


host in AT mode as a drive select. If HDS = 0, 
then drive 1 is selected. If HDS = 1 , then drive 2 is 
selected. This bit is always accessable to the 
microcontroller regardless of the state of ABSY. 

3.7.14.5 BIT 3 MICROCONTROLLER ACCESS 
CONTROL 

This bit reflects the state of the microcontroller 
access control bit defined in the drive interface 
control register. 

3.7.14.6 BIT 2 DISABLE RESET OUTPUT 

This bit reflects the state of the disable reset out- 
put control bit defined in the drive interface control 
register. 

3.7.14.7 BIT 1 INPUT POLARITY 

This bit reflects the state of the input polarity con- 
trol bit defined in the drive interface control 
register. 

3.7.14.8 BIT 0 DISABLE SECTOR NUMBER 

This bit reflects the state of the disable sector 
number control bit defined in the drive interface 
control register. 

3.7.15 DRIVE INTERFACE CONTROL 
(AD7 THRU ADO = 3B, WRITE) 

This register is used to control the drive controller. 
It is coded as follows: 


Bit 

7 

6 

5 

4 

3 

2 1 0 

RDC 

X 

X 

X 

MAC 

DRQ IPOL DSN 


3.7.15.1 BIT 7 RESET DRIVE CONTROLLER 

When this bit is asserted, then the drive controller 
subsection of the WD42C22C resets. It is held 
reset as lo ng as t he bit is asserted. This bit is 
reset when RESET is asserted. 

3.7.15.2 BIT 3 MICROCONTROLLER ACCESS 
CONTROL 

When this bit is set, the microcontroller is tied to 
the buffer RAM through the disk controller’s port. 
The microcontroller can then read or write the 
buffer by reading from or writing to the RAM ac- 
cess port (36i6). The DRWB bit in the buffer 
manager control port should be set to the proper 
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state before this bit is set. When MAC = 1 , then 
the disk controller task file (registers 21 16 through 
27^e) cannot be accessed by the microcontroller. 
If the microcontroller writes to these registers 
when MAC = 1 , then the disk cont roller m ay not 
act properly. This bit resets when RESET is as- 
serted. The proper sequence for the 
microcontroller to read/write the RAM is defined 
under the buffer manager description. 

3.7.15.3 BIT 2 DISABLE RESET OUTPUT 

When this bit is set, all ho st initiat ed soft resets 
are disabled. Instead of the RESET li ne bein g as- 
serted on soft reset, only the MCINT line 
is asserted. It is the responsibility of the local 
microcontroller to properly reset the board 
hardware when this bit is set. This bit resets only 
during power-up. 

3.7.15.4 BIT 1 INPUT POLARITY 

This b it is u sed to c ontrol t he polarity of the 
INDEX, SCT, WF, and DRDY inputs. If IPOL= 0, 
the default, then the inputs are active low. 
If IPOL = 1, then the inputs are active high. In 
soft sector MFM and RLL modes, DRUN is al- 
ways active high regardless of the state of IPOL. 

3.7.15.5 BIT 0 DISABLE SECTOR NUMBER 

When this bit is set, then the drive controller does 
not compare the sector number coming from the 
drive with the desired sector number when reads 
or writes are performed. The drive con- 
troller instead writes the sector number coming 
from the drive into the sector number register in 
the drive controller task file. At the end of each 
sector, just prior to issuing DRQI or DCI, the drive 
controller always writes the sector number to the 
altern ate sect or number register. This bit resets 
when RESET is asserted. 

3.7.16 ALTERNATE SECTOR NUMBER 
(AD7 THRU ADO = 3C, READ) 

When the disk controller interrupts the 
microcontroller, this register holds the sector 
number of the sector just read or written. It is 
always updated just prior to the disk BDRQ inter- 
rupt (DRQI) or the disk controller interrupt (DCI). It 
is initialized to FFi6 at the start of every com- 
mand. It is written regardless of the state of the 
DSN bit described above. 


Bit 

7 6 5 4 3 2 1 0 

NUMBER OF LAST SECTOR READ OR 
WRITTEN 

3.8 AT INTERFACE PORTS 

3.8.1 AT CONTROL REGISTER 

(AD7 THRU ADO = 2A, READ/WRITE) 

This register controls the new auto-DRQ option 
for write, write long, and format commands. 


Bit 

7 

6 

5 

4 

3 

2 1 0 

0 

0 

0 

0 

0 

0 ADQ7ADRQ 


3.8.1 .1 BITS 7 THROUGH 2 RESERVED 

Set to 0. 


3.8.1 .2 BIT 1 AUTO-DRQ 7 BYTE ECC 

When ADRQ = 1 and ADQ = 1, then 7 ECC bytes 
are transferred to/from the host on a read long or 
write long command. When ADRQ = 1 and ADQ7 
= 0, then 4 ECC bytes are transferred to/from the 
host on a read long or write long command. When 
ADRQ = 0, then the ECC7 bit in the fixed disk 
register (3Fi 6) controls the number of ECC bytes 
transferred on read long and write long com- 
mands. 

3.8.1 .3 BIT 0 AUTO-DRQ ENABLE 

When ADRQ = 1 in AT mode, then the 
WD42C22C automatically sets up the first data 
transfer from the host for write, write long, and 
format commands. When ADRQ = 0, the local 
microcontroller must set up all data transfers 
to/from the host for all commands. 

3.8.2 DRIVE ZERO STATUS 

(AD7 THRU ADO = 3D, READ/WRITE) 

In PC/AT mode, bits 6, 5, 4, 2, and 0 of the host 
status register are controlled by the local 
microcontroller. Bits 6, 5, 4, 2, and 0 of the host 
status register are set to the values of bits 6, 5, 4, 
2, and 0, respectively, of this register if bit 4 of the 
AT task file copy SDH register (port 46 for 
microcontroller, port 6 for host) is 0. The other bits 
of the host status are not affected by this register. 
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3.8.3 DRIVE ONE STATUS 

(AD7 THRU ADO = 3E, READ/WRITE) 

In AT mode, bits 6, 5, 4, 2, and bit 0 of the host 
status register are controlled by the local 
microcontroller. Bits 6, 5, 4, 2, and 0 of the host 
status register is set to the values of bits 6, 5, 4, 2, 
and 0, respectively, of this register if bit 4 of the AT 
task file copy SDH register (port 46 for 
microcontroller, port 6 for host) is 1 . The other bits 
of the host status are not affected by this register. 

3.8.4 FIXED DISK REGISTER 
(AD7 THRU ADO = 3F, READ) 

This register contains the fixed disk register data 
written by the host. 


Bit 

7 

6 

5 

4 3 2 1 

0 

0 

0 

0 

0 HS3ENRSTIEN 

0 


3.8.5 DIGITAL INPUT REGISTER 

(AD7 THRU ADO = 3F, WRITE) 

Bit 5 of this register is written by the local 
microcontroller and read by the host if the fixed 
disk register bit 3 is zero. This bit is inverted when 
this register is read by the host. If HS3EN is one, 
then bit 5 of this register comes from SDH register 
bit 3. 


Bit 

7 6 5 

4 

3 

2 

1 

0 

ECCM ECC7/ RWC 
DDRQ 

X 

X 

X 

DS1 

DSO 


3.8.5. 1 BIT 7 ECC MODE 

In PC/AT mode, ECCMOD = 1 indicates that the 
data transferred to the host includes ECC. The 
ECC is transferred in bytes ra ther than in words. 
This bit is reset when RESET is asserted. This bit 
should not be set in XT or slave host modes. 

3.8.5.2 BIT 6 ECC 7 BYTES/ DISABLE BDRQ 

When ECCM = 1, then this bit determines the 
number of ECC bytes transferred to the host. If 
ECC7 = 1, then 7 bytes are transferred. Other- 


wise, 4 bytes are transferred. If ECCM = 0, then 
this bit controls whether or not the drive con- 
troller issues BDRQ interrupts. If DDRQ = 0, 
then the drive controller issues BDRQ inter- 
rupts. If DDRQ = 1, then the drive controller does 
not issue BDRQ interrupts. It should be noted that 
when BDRQ occurs, the buffer manager loads the 
disk pointer from its pipeline register and when no 
BDRQ occurs then the disk pointer keeps in- 
crementing f rom one sector to the next. This bit 
resets when RESET is asserted. 

3.8.5.3 BIT 5 REDUCE WRITE CURRENT 

This bit is set by the micro controller and indi- 
cates the state of the RWC signal going to the 
drive. 

3.8.5.4 BIT 1 DRIVE SELECT 1 

This bit controls the state of the D S1 output pin. 
When DS1 = 0, then the DS1 out put is tri- 
stated and when DS1 = 1 the DS1 output is 
low. This bit is reset when RESET is asserted. 

3.8.5.5 BIT 0 DRIVE SELECT 0 

This bit controls the state of th e DSO output pin. 
When DSO = 0, then the DSO output is tri-stated 
and when DSO = 1 the th e DSO output is low. This 
bit is reset when RESET is asserted. 

3.8.6 AT TASK FILE COPY 

(AD7 THRU ADO = 40 THRU 47, 
READ/WRITE) 

These registers are a copy of the disk controller 
task file. They are loaded by the host prior to the 
start of a command. The local microcontroller 
must read the command and interpret it and then 
copy the appropriate parameters from this task 
file copy to the actual drive controller task file 
(20i6-27i6). At the end of the command, the local 
microcontroller must update this task file copy 
before asserting INTRQ and resetting ABSY. The 
local microcontroller can only access these 
registers when ABSY=1 . 
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4.0 BUFFER MANAGER ORGANIZA- 
TION 

The buffer manager can control multiple sector 
buffers totalling up to 32 Kbytes. The buffer inter- 
face requires static RAMs. The sector buffers can 
be any size up to 2055 bytes, including ECC, and 
can be located at any byte boundary. The buffer 
manager has two address counters, one for the 
host interface and one for the disk data buffer. 
Both counters can access the SRAM simul- 
taneously. The buffer manager handles the ar- 
bitration between the host interface and the drive 
controller. There is a FIFO in the host data inter- 
face that allows a sustained bandwidth of 4 
Mwords/sec (8 Mbytes/sec) for 16-bit wide trans- 
fers and 8 Mbytes/sec for 8-bit wide transfers. 
The buffer manager can sustain a RAM 
bandwidth of 10 Mbytes/sec. 

When the local microcontroller wants to access 
the buffer RAM, it has to use the disk buffer 
manager logic. It first loads the desired starting 
address into the disk buffer pointer. The proper 
buffer manager control bits are then set to enable 
the local microcontroller access to the buffer. 
When the local microcontroller accesses the spe- 
cial RAM access port (register 36i6), the data is 
read/written through the disk controller’s FIFO 
port to the buffer. The RAM can only be accessed 
sequentially from the starting address and only in 
one direction as set by the DRWB control bit in 
the buffer control register. 

Both address counters are pipelined. There are 
registers that can be loaded with the starting ad- 
dress of the next sector buffer while the current 
buffer is transferring. This allows noncontiguous 
buffers to be chained without any loss of RAM 
bandwidth between sectors. 


4.1 ACCESSING BUFFER RAM FROM THE 
MICRO-CONTROLLER 

The microcontroller can read and write the buffer 
RAM. To read the buffer RAM the procedure is: 

1 . Set DRWB = 1 (bit 2) in the buffer manager 
control Register (37i6). 

2. Set MAC = 1 (bit 3) in the disk controller con- 
trol register (3Bi6). 

3. Load the starting address of the data being 
accessed into the disk buffer pointer 
registers (34 & 35i6). 

4. Set ADBP = 1 (bit 0) in the buffer manager 
control register (37i6). 

The buffer manager begins reading data out of 
the RAM starting at the address specified in the 
disk pointer register and placing it into the FIFO. 
As the microcontroller reads from the RAM ac- 
cess port (36i6), sequential bytes from the buffer 
are transferred from the FIFO to the 
microcontroller. 

The procedure to write to the buffer RAM is: 

1 . Set DRWB = 0 (bit 2) in the buffer manager 
control register (37i6). 

2. Set MAC = 1 (bit 3) in the disk controller con- 
trol register (3Bi6). 

3. Load the starting address of the data being 
accessed into the disk buffer pointer 
registers (34 & 35i6). 

4. Set ADBP = 1 (bit 0) in the buffer manager 
control register (37i6). 

As the microcontroller writes data to the RAM ac- 
cess port (36i6), the buffer manager transfers the 
bytes to sequential locations in the buffer RAM 
starting at the address specified in the disk pointer 
register. 

NOTE 

DRWB should not be changed while MAC = 1 . 
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4.2 STARTING HOST TRANSFERS 
TO/FROM BUFFER RAM 

Host transfers can be performed in several 
modes. The modes available and the setup re- 
quired to establish each mode are as follows: 


HDMA 

BDEN 

BCNT 

HI 6/8- 

1 

0 

X 

0 

8-bit wide single byte DMA 


1 

0 

X 

1 

1 6-bit wide single word DMA 


1 

1 

0 

0 

1 8-bit wide, 8-byte burst DMA 


1 

1 

0 

1 

[ 1 6-bit wide, 1 6-byte burst DMA 


1 

1 

1 

0 

! 8-bit wide, continuous burst DMA 


1 

1 

1 

1 

1 6-bit wide, continuous burst DMA 


0 

X 

X 

0 

8-bit wide PIO 



0 

X 

X 

1 

16-bit wide PIO 




Bits HDMA (bit 7), BCNT(bit 5), and HI 6/8 (bit 1) 
are in the auxiliary buffer manager control 
register (2Fi6) and bit BDEN (bit 1) is in the buffer 
manager control register (37i6). All of these 
modes are available in both the XT and AT host 
configurations. All of the DMA modes are avail- 
able in the slave host configuration. 

To perform a Host read data transfer the following 
sequence should be followed. 

1 . Set up the appropriate transfer mode as 
described above. 

2. Set HRWB = 1 (bit 3) in the buffer control 
register (37 1 6). 

3. Load the starting address of the desired sec- 
tor into the host pointer registers (30i6 & 

31 16 ). Load the number of bytes into the host 
transfer count registers (32i6 & 33i6). 

4. Set AHBP = 1 (bit 4) in the buffer manager 
control register (37i6). Hardware automat- 
ically sets DRQ (bit 3) and resets ABSY (bit 


7) in the host status register if AT mode and 
sets REQ (bit 0) in the hardware status 
register if XT mode. If DMA transfers are 
enabled, then the hardware automatically 
starts the DMA handshake when AHBP is 
set by the micro-controller. 

5. Wait for HPRI = 1 (bit 2) in the interface 
status register (38i6). MCINT is asserted. 

6. Set RHRI = 1 (bit 2) in the interface control 
register (38i6) to reset the interrupt. If chain- 
ing and still more sectors then go to 3. 

7. Wait for HPRI = 1 (bit 2) in the interface 
status register (38i6). MCINT is be asserted. 

8. Set RHRI = 1 (bit 2) in the interface control 
register (38i6) to reset the interrupt. If still 
more sectors, then go to 3. 

9. Set RBSY = 1 (bit 3) in the interface control 
register when the entire command sequence 
is complete. This resets the ABSY and 
XBSY host status bits. They stay reset until 
the next command is issued by the host. 

To perform a host write data transfer, he following 

sequence should be followed. 

1 . Set up the appropriate transfer mode as 
described above. 

2. Set HRWB = 0 (bit 3) in the buffer control 
register (37i6). 

3. Load the starting address of the desired sec- 
tor into the host pointer registers (30i6 & 

31 16 ). Load the number of bytes into the host 
transfer count registers (32i6 & 33i6) 

4. Set AHBP = 1 (bit 4) in the buffer manager 
control register (37i6). Hardware automat- 
ically sets DRQ (bit 3) and resets ABSY (bit 
7) in the host status register if AT mode and 
set REQ (bit 0) in the hardware status 
register if XT mode. If DMA transfers are 
enabled, then the hardware automatically 
starts the DMA handshake when AHBP is 
set by the micro-controller. 

Wait for HPRI = 1 (bit 2) in the interface 
status register (38i6). MCINT is asserted. 
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6. Set RHRI = 1 (bit 2) in the interface control 

register (38i6) to reset the interrupt. If chain- 
ing and still more sectors then go to 3. 

7. Wait for second HPRI = 1 ( bit 2) in t he inter- 

face status register (38i6). MCI NT is as- 
serted. 

8. Set RHRI = 1 (bit 2) in the interface control 

register (38i6) to reset the interrupt. If still 
more sectors then go to 3. 

9. Set RBSY = 1 (bit 3) in the interface control 

register when the entire command sequence 
is complete. This resets the ABSY and XBSY 
host status bits. They stay reset until the 
next command is issued by the host. 

4.3 CONTROLLER COMMANDS 

The WD42C22C Winchester command set con- 
tains twelve commands. Four commands (read 
sector, write sector, format, and set parameter) 
are directly executed through the command 
register. The remaining commands are not directly 
available to the host. These commands may be 
executed by the local microcontroller transparent- 
ly to the host. Table 12 lists the commands and 
command codes. 


COMMAND 

7 

6 

5 

4 

3 

2 

1 

0 

Read Sector 

0 

0 

1 

0 

0 

M 

L 

T 

Read Next Data 

0 

1 

1 

0 

0 

0 

L 

1 

Write Sector 

0 

0 

1 

1 

X 

M 

L 

T 

Write ID 

1 

0 

1 

1 

F 

0 

A 

T 

Scan ID 

0 

1 

0 

0 

0 

0 

0 

T 

Format Track 

0 

1 

0 

1 

0 

0 

W 

1 

Format Single Sector 

1 

1 

0 

1 

0 

0 

W 

1 

Compute Correction 

0 

0 

0 

0 

1 

P 

0 

0 

Set Parameter 

z 

0 

0 

R 

0 

E 

H 

S 

Load Parameter Block 

1 

0 

0 

0 

1 

D 

K 

U 

Sleep 

1 

0 

0 

1 

1 

0 

0 

0 

Dump 

1 

0 

1 

0 

1 

B 

L 

1 


TABLE 12. COMMAND AND COMMAND CODES 


Mnemonic definitions for Table 1 2: 

• M=0 Single sector read or write. Sector count 
is ignored. 

M=1 Multiple sector read or write. Used for 
1:1 interleave. 


• L=0 

Normal mode, selected ECC or CRC 
functions performed. 

L=1 

Sector extended by 4 or 7 bytes (de- 
pends on set parameter command. 

No ECC generated or checked. 

• T=0 

Enable retries. 

T=1 

Disable retries. 

• X=0 

Write sector specified in sector number 
register. 

X=1 

Write sector specified in first byte of 
the sector buffer. 

• F=0 

Write new ID immediately after current 
ID. 

F=1 

Write new ID offset from current ID. 

• A=0 

Do not pulse AME when writing new 

ID. 

A=1 

Pulse AME when writing new ID. 

• W=0 

Write gate stays asserted for entire 
track or sector. 

W=1 

Write gate deasserted over all gaps 
during format. 

• P=0 

Transfer syndrome bytes to buffer and 
calculate error pattern bytes and 
transfer them to the buffer. 

P=1 

Transfer syndrome bytes to the buffer 
but do not calculate error pattern 
bytes. 

• Z=0 

MFM or RLL mode. 

Z=1 

NRZ mode. Mode used for ESDI drive 
interface. 

• R=0 

Disable relocation ID searches. 

R=1 

Enable relocation ID searches. 

• E=Q 

Sector extension for read long/write 
long 4 bytes. ECC generator/checker 
is 4 bytes. 

E=1 

Sector extension for read long/write 
long 7 bytes. ECC generator/checker 
is 7 bytes. 

• H=0 

SDH register programmed for 3 head 
select bits. 

H=1 

SDH register programmed for 4 head 
select bits. 

• S=0 

Error correction span 5 bits with 4 
byte ECC or 1 1 bits with 7 byte ECC. 

S=1 

Error correction span 1 1 bits with 4 
byte ECC or 22 bits with 7 byte ECC. 

• D=0 

Select soft sector drive interface. De- 
fault after master reset. 

D=1 

Select hard sector drive interface. In 
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MODE 

MODE 

CONTROL 

OPTIONS 


Z 

D 

K 


M 

T 

L 

X 

A 

F 

R 

s 

E 

H 

p 

u 

w 

1 

B 

RLL soft sector 

? 

0 

0 

X 

X 

X 

X 

X 

X 

X 

X 

★ 

X 

X 

X 




RLL hard sector 

? 

1 

0 

X 

X 

X 

X 

X 

X 

X 

X 

* 

X 

X 

X 

X 

X 

X 

MFM soft sector 

0 

0 

1 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 




MFM hard sector 

0 

1 

1 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

NRZ soft sector 

1 

0 

1 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 




NRZ hard sector 

1 

1 

1 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 

X 


? Don’t care, could be 0 or 1 . 
x These options are supported. 
* These options have no effect. 


TABLE 13. OPTION SUMMARY TABLE 


this mode, DRUN becomes a sector 
pulse input. 

• K=0 RLL data interface. Selection of this 

option disables the NRZ option. De- 
faults to this setting after master re- 
set. 

K=1 Data interface is either MFM or NRZ. 

• U=0 Use the standard sector sizes defined 

under the SDH register description. 

U=1 Select user defined sector size. The 
desired sector size is put into the 
cylinder registers prior to issuing a 
load parameter block command. The 
auxilliary set parameter command 
transfers the desired sector size from 
the cylinder registers to an internal 
sector size register. 

• 1=0 Dump two fields per sector. Dump 5 ID 

bytes and the number of data bytes 
set by the sector size. 
i=1 Dump only one field per sector. The 
sizeof the field is set by the sector 
size and type of field (ID versus data) 
is controlled by where RG is asserted. 

• B=0 FE sync byte and zero preset CRC. 

B=1 A1 sync byte and ones preset CRC. 

Table 13 summarizes the data formats and op- 
tions supported by these formats. 


4.4 COMMAND DESCRIPTIONS 
4.4.1 READ SECTOR 

If M = 0, then the sector specified in sector num- 
ber register is read. If M = 1 , then multiple records 
are read. If the sector count register = 0, then 256 
sectors are read at the desired track. 

If T=0, then ID searches are retried for 10 index 
pulses. DAM not found errors are not retried. 
There are no retries for CRC/ECC errors. If T=1 , 
ID searches are retried for two index pulses. 

If L=0, then normal CRC or ECC read commands 
are performed. If L=1, then the CRC or ECC 
check bytes are not computed but instead the 
CRC or ECC check bytes are loaded into the buff- 
er immediately after the data field. The external 
sector buffer must be long enough to hold the 
additional 4 or 7 bytes. If ECC and retry modes 
have been selected and a data field error occurs 
there are no attempts to correct the data. 

A bad block mark in the ID field sets the error bit 
and the data field is not read. If the R option in the 
set parameter command is set then the controller 
searches immediately after the normal ID field for 
a special ID field containing mapping information 
and a special "Relocation ID" flag bit. The RIDF 
bit in the error register sets if this special ID field 
is found. If a bad block mark is found in an ID 
field then the command terminates immediately 
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even if more sectors remain to be read. The task 
file contents when a bad block bit is detected and 
the R option is used is as follows: 


REGISTER 

MEANING 

22 

Sector number of sector with 
bad block bit set 

23 

Sector umber where sector 
has been relocated 

24 

LSB of cylinder number 
where sector has been reloc- 
ated 

25 

MS bits of Cylinder where 
sector has been relocated 

26 

Head number of relocated 
sector 


If DSN = 1 (bit 0) in the drive interface control 
register (3Bi6) than the sector number is not com- 
pared when ID searches are performed. The 
WD42C22A reads the sector as long as the 
cylinder and head numbers match the desired 
values. This allows an interleaved track to be read 
into the buffer in one revolution. 


Command Flow: 


• MICRO: 


1. Set DRWB = 0 (bit 2) in the 
buffer manager control reg- 
ister (37 16 ). 

2. Load the starting address of 
the first sector into the disk 
buffer pointer registers (34i6 
&35ie). 

3. Set ECCM = 0 (bit 7) and 
DDRQ = 1 (bit 6) in the DIR 
write register (3Fi6) and 
MAC=1 (bit 3) in the drive 
interface control register 
(3Bi6) to disable DRQI, if 
desired. 

4. Set ADBP = 1 (bit 0) in the 
buffer manager control reg- 
ister (37i6). 

5. Set MAC = 0 in the drive 
interface control register. 

6. Issue read command to 
WD42C22C. 


• WD42C22C: 7. Write FF to alternate sector 
number register (3Ci6). 
Abort if drive not ready or 
write fault. 

8. (If DRQI is enabled) 


• MICRO 


• WD42C22C: 9. 

10 . 

11. 

12. 


13. 


Activate BDRQ signal to 
buffer manager and DRQI to 
microcontroller. Wait for 
BRDY signal indicating trans- 
fer of buffer pointer. 

Load starting address of next 
sector buffer into disk buffer 
pointer register. Set ADBP=1 
in buffer manager control reg- 
ister if more sectors remain- 
ing. Set RDQI (bit 1 ) in the 
interface control register 
(38ie). 

Search for head, cylinder, 
sector number, and sector 
size code. 

When the proper sector ID is 
found, read sector data and 
place in buffer. 

Write sector number to alter- 
nate sector number register. 

If M = 0, then go to 10. 
Decrement sector count, in- 
crement sector number. If 
M = 1 , and sector count = 0 
then go to 13 else go to step 
8 . 

Set DCI (bit 3) in the inter- 
face sta tus register (38i6). 
MCI NT asserted. 


• MICRO: 14. Read disk controller status 

register (27i 6) and error 
register (21 16 >- 


Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
activated. 

• ID not found set if ID field not found or 

if ID field matches, but CRC check fails, and 
after retry procedure. 

• Bad block set if attempt was made to read a 
sector with bad block mark. 

• Relocation ID found if R option enabled and 
relocation ID detected. 

• Data CRC/ECC set if data field CRC or ECC 
check fails. No attempt is made to correct 
ECC errors. 

• Data AM not found in set if data address mark 
not found. 
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4.4.2 READ NEXT DATA 

The read next data command finds the next data 
field and places it in a buffer. If the WD42C22C 
detects that the drive number changed since the 
last read command, then an auto-scan ID is per- 
formed and step pulses are issued to update the 
present cylinder position. 

All searches for a data field are retried for two 
index pulses, but if a data ECC error is detected 
there are no retries. If after reading the correct ID 
field, the data address mark is not found a DAM 
error is set. 

The L flag controls the ECC check bytes. If L=0, 
then the data field is read and ECC is checked. If 
L=1, then the ECC check bytes are not computed. 
Instead, the ECC check bytes are loaded into the 
buffer immediately after the data field. The exter- 
nal sector buffer must be long enough to hold the 
additional 7 bytes. 

NOTE 

This command supports only soft sector MFM and 
RLL mode and is implemented for backward com- 
patibility with the WD5011 and WD5011A. 

Command Flow : 

• MICRO: 1 . Set DRWB = 0 (bit 2) in the 

buffer manager control reg- 
ister (37i6). 

2. Load the starting address of 
the first sector into the disk 
buffer pointer registers 
(34 i6&35i 6 ). 

3. Set ADBP = 1 (bit 0) in the 
buffer manager control reg- 
ister (37 16). 

4. Set ECCM = 0 (bit 7) and 
DDRQ = 1 (bit 6) in the DIR 
write register (3Fi 6) and 
MAC=1 (bit 3) in the drive 
interface control register 
(3Bi6) to disable DRQI, if 
desired. 

5. Set MAC=0 in the drive inter- 
face control register. 

6. Issue read next data com- 
mand to WD42C22C. 

• WD42C22C: 7. Write FF to alternate sec- 

tor number register (3Ci6). 
Abort if drive not ready or 
write fault. 


8. (If DRQI is enabled) 

Set DRQ status bit, activate 
BDRQ signal to buffer man- 
ager. Wait for BRDY signal 
indicating transfer of buffer 
pointer. 

• MICRO: Set RDQI (bit 1) in the inter- 

face control register (38i6). 

• WD42C22C: 9. Find next data field, read sec- 

tor data and place in buffer. 

If data mark error, try data 
field search again until 2 in- 
dex pulses occur. 

1 0. Copy sector number register 
to alternate sector number 
register (3Ci6). Set DCI 
(bit 3) in the int erface s tatus 
register (38i6). MCINT is 
asserted. 

• MICRO: 1 1 . Read disk controller status 

register (27i6) and error 
register (21 16). 

Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
activated. 

• Data CRC/ECC set if data field CRC or ECC 
check fails. No correction is attempted. 

• Data AM not found is set if data address mark 
not found after 2 index pulses of looking for 
any data field. 

4.4.3 WRITE SECTOR 

Write from buffer to disk when BRDY signal is 
activated by the buffer manager. Write total num- 
ber of sectors specified by sector count register if 
M = 1 . Sectors are written in numerical order. If M 
= 0, then sector count is ignored and only one 
sector is written. The data field PLO sync field is 
nominally 12 bytes long but is extended by the 
PLO register. 

If T = 0, then ID searches are retried for 10 index 
pulses. If T = 1, then ID searches are retried for 2 
index pulses only. 

If L = 0, then normal CRC or ECC write sector 
commands are performed. If L = 1 , then the CRC 
or ECC check bytes are not computed and written 
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to the disk but instead, 4 or 7 additional bytes are 
read from the buffer and written to the disk imme- 
diately after the data field. 

If X = 0, then the controller searches for the sector 
number in the sector number register and incre- 
ments the sector number register and the end of 
each sector if M = 1 . If X = 1 , then the controller 
searches for the sector specified in the first byte 
of the sector buffer. The controller reloads the 
sector number register from the first byte of each 
subsequent sector buffer if M = 1 . This allows a 
track formatted with interleave to be written in one 
revolution. 

A bad block mark in the ID field sets the error bit 
and the data field is not be written. If the R option 
in the set parameter command is set, then the 
controller searches immediately after the normal 
ID field for a special ID field containing mapping 
information and a special "Relocation ID" flag bit. 
The RIDF bit in the error register sets if this spe- 
cial ID field is found. If a bad block mark is found 
in an ID field then the command terminates imme- 
diately even if more sectors remain to be read. 
The task file contents when a bad block bit is 
detected and the R option is used is as follows: 


REGISTER 

MEANING 

22 

Sector number of sector with 
bad block bit set 

23 

Sector number where sector 
has been relocated 

24 

LSB of cylinder number where 
sector has been relocated 

25 

MS bits of cylinder where sec- 
tor has been relocated 

26 

Head number where sector 
has been relocated 


If DSN = 1 (bit 0) in the drive interface control 
register (3Bi6) then the sector number is not com- 
pared when ID searches are performed. The 
WD42C22C writes the sector as long as the 
cylinder and head numbers match the desired 
values. This allows an interleaved track to be writ- 
ten into the buffer in one revolution. This option is 
only useful when doing the initial write-after-for- 
mat to place 00 in the data fields. 


Command Flow: 


•MICRO: 1. 

Set DRWB = 1 (bit 2) in the 
buffer manager control reg- 
ister (37i6). 

2. 

Load the starting address of 
the first sector into the disk 
buffer pointer registers 
(34i6&35ie). 

3. 

Set ECCM = 0 (bit 7) and 
DDRQ = 1 (bit 6) in the DIR 
write register (3Fi 6) and 

MAC = 1 (bit 3) in the drive 
register (3Bi6) to disable 
DRQI, if desired. 

4. 

Set ADBP=1 (bit 0) in the 
buffer manager control reg- 
ister (37i6). 

5. 

Set MAC = 0 in the drive 
interface control register. 

6. 

Issue write command to 
WD42C22C. 

• WD42C22C: 7. 

Write FF to alternate sector 
number register (3Ci6). 

Abort if drive not ready or 
write fault. 

8. 

(If DRQ is enabled.) 

Activate BDRQ signal to 
buffer manager and DRQI to 
microcontroller. Wait for 
BRDY signal indicating 
transfer of buffer pointer. 

• MICRO: 

Load starting address of next 
sector buffer into disk buffer 
pointer register. Set ADBP=1 
in buffer manager control 
register if more sectors re- 
maining. Set RDQI (bit 1) in 
the interface control register 
(38ie). 

• WD42C22C: 9. 

Search for head, cylinder, 
sector number and sector 
size code. 

10. 

When the proper sector ID 
is found, write buffer data to 
sector. 

11. 

Write sector number to alter- 
nate sector number register 
(3Ci6). If M = 0 then go to 


13. 

1 2. Decrement sector count, in- 
crement sector number. If 
M = 1 and sector count = 0 
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then go to 1 3 else go to step 
8. 

13. Set DCI (bit 3) in the inter- 
face sta tus register (38i6). 
MCINT asserted. 

• MICRO: 14. Read disk controller status 

register (27^e) and error 
register (21 16>- 

Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
activated. 

• ID not found set if exact ID field not found or if 
ID field matches but CRC check fails, after 
retry procedure. 

• Bad Block set if write sector attempted on any 
sector with bad block mark. 

• Relocation ID found if R option enabled and 
relocation ID detected. 

4.4.4 WRITE ID 

Write from buffer to disk when BRDY signal is 
activated by the buffer manager. Write 4 bytes to 
create an ID field. The PLO sync field prior to this 
new ID field is nominally 12 bytes long but is ex- 
tended by the PLO register. A value of 0 results in 
a 2048 byte PLO field and should not be used. 

If T = 0 then ID searches are retried for 10 index 
pulses. If T = 1, then ID searches are retried for 2 
index pulses only. 

If F = 0, then the new ID is written immediately 
after the ID field of the desired sector. If F = 1, 
then the new ID field is written offset from the 
desired sector ID with the offset determined by 
the internal sector size register. A load parameter 
block command will have to be issued to set the 
offset value and another load parameter block will 
be needed to set the sector size back to the cor- 
rect value if the programmable sector size option 
is being used. An offset of up to 2048 is allowed. 
This option can be used to reformat a single sec- 
tor in soft sector mode. 

If A = 0, then the AME output is held low during 
the write ID command. If A = 1, then the AME 
output is pulsed at the start of the PLO field 
before the new ID being written. This option, 


together with the F option, can be used to refor- 
mat a single sector in soft sector NRZ mode. 

The four bytes in the buffer (F = 0) should be as 

follows: 

BYTE0: 1 1 1 1 cyllOl cyl 9 cyl 8 

BYTE 1 : Low byte of cylinder number 
BYTE 2: BB 0 RF 0 HS3 HS2 HS1 HS0 
BYTE 3: Sector Number 

BB = bad block flag 
RF = Relocation ID flag 

cyl 1 0 thru cyl 8 = upper three cylinder num- 
ber bits 

HS3 thru HS0 = head select bits 
The five bytes in the buffer (F = 1) should be as 
follows: 

BYTE 0: Sector Number 
BYTE 1 : 1 1 1 1 cyl 1 0 1 cyl 9 cyl 8 

BYTE 2: Low byte of cylinder number 
BYTE 3: BB 0 RF 0 HS3 HS2 HS1 HS0 
BYTE 4: Sector Number 

BB = bad block flag 
RF = Relocation ID flag 

cyl 1 0 thru cyl 8 = upper three cylinder num- 
ber bits 

HS3 thru HS0 = head select bits 

RF should be set to 1 if the new ID being written 
is to be a special relocation ID for mapping a 
defective sector to a new position. 

Command Flow: 

• MICRO: 1 . Set DRWB = 1 (bit 2) in the 

buffer manager control regis- 
ter (37 i 6 ). 

2. Load the starting address of 
the ID buffer data into the 
disk buffer pointer registers 
(34i6&35ie). 

3. Set ECCM = 0 (bit 7) and 
DDRQ = 1 (bit 6) in the DIR 
write register (3Fi 6) and 
MAC = 1 (bit 3) in the drive 
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interface control register 
(3Bi6) to disable DRQI, if 
desired. 

4. 

Set ADBP = 1 (bit 0) in the 
buffer manager control regis- 
ter (37i6). 

5. 

Set MAC = 0 in the drive 
interface control register. 

6. 

Issue Write ID command to 
WD42C22C. 

• WD42C22C: 7. 

Write FF to alternate sector 
number register (3Ci6). 

Abort if drive not ready or 
write fault. 

8. 

(If DRQI is enabled) 

Activate BDRQ signal to buff- 
er manager and DRQI to 
microcontroller. Wait for 

BRDY signal indicating trans- 
fer of buffer pointer. 

• MICRO: 

Set RDQI (bit 1) in the inter- 
face control register (38i6). 

• WD42C22C: 9. 

Search for head, cylinder, 
sector number and sector 
size code. 

10. 

When the proper sector ID is 
found, write buffer data to 
sector. 

• WD42C22C:11. 

Write sector number to alter- 
nate sector number register. 
Set DCI (bit 3) in the interface 
status reaister (38i6). 

MCINT asserted. 


number and sector number are loaded into the 
respective registers. 

Command Flow: 


• MICRO: 1 . Issue Scan ID command to 

WD42C22C. 


• WD42C22C 2. 


3. 


4. 


Write FF to alternate sec- 
tor number register (3Ci6). 
Abort if drive not ready or 
write fault. 

Search for next ID field and 
read 4 ID bytes into respec- 
tive registers. Search for ID 
field for up to 10 index pulses 
if T=0, up to 2 index pulses if 
T=1 . 

Set DCI (bit 3) in the interface 
status r egister (38i6). 

MCINT asserted. 


• MICRO: 5. Read disk controller status 

register (27 1 6) and error 
register (21 16 >- 


Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
active. 

• Bad Block set if bad block mark detected. 

• ID not found if no ID fields are found. 

• Relocation ID found if R option enabled and 
relocation ID detected. 


• MICRO: 1 2. Read disk controller status 

register (27i6) and error 
register (21 1 6). 

Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write Fault and aborted command set if WF 
pin activated. 

• ID not Found set if exact ID field not found or if 
ID field matches but CRC check fails, after 
retry procedure. 

• Bad Block set if bad block bit detected in ID of 
desired sector. 

4.4.5 SCAN ID 


4.4.6 FORMAT TRACK 

This command formats one track using 
parameters loaded in the task registers file and in 
buffer memory. 

Cylinder, head, and sector size numbers are 
taken from the task register file. Good block/bad 
block marks and sector numbers are taken from 
buffer memory. The total number of sectors for- 
matted is specified by the sector count register. 
The lengths of GAP 1 and GAP 3 are loaded into 
the sector number register. The length of the ID 
PLO sync field is loaded into the PLO length 
register if B = 1. The data PLO field length is 12 
bytes during format. 


When the next ID field of the present track is en- The data placed in the gaps comes from an inter- 
countered, cylinder number, sector size, head nal register loaded during the load parameter 
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block command. The data placed into the pads 
comes from another internal register loaded 
during the load parameter block command. 

After the task register file has been loaded with 
the desired format parameters and the block 
marks and sector addresses have been loaded 
into the buffer then the command register is 
loaded with the format command. When the 
BRDY signal is activated by the buffer manager, 
the specified number of sectors are written. The 
block marks and sector numbers are read from 
the buffer as needed. The data field is written with 
FF. CRC is automatically computed and written if 
in CRC mode. If in ECC mode, ECC check bytes 
are automatically computed and written after the 
data field. The number of ECC check bytes is 
determined by the E bit in the set parameter com- 
mand. 

Write Gate is turned on and off within 4 bit times 
after index if NRZ or hard sector mode is selected 
or within 6 bit times otherwise. In RLL mode, 
Gap1/Gap3 data should be programmed to be 
33i6 with the load parameter command. The W 
option controls the state of WRITE GATE over the 
gaps. If W=1, WRITE GATE turns off over the 
gaps. 

The sum of the number of bytes in both the 
Gap1/Gap3 and ID PLO field must be greater 
than or equal to 25 bytes to achieve 1:1 inter- 
leave. 

The interleave table contains the bad block marks 
and sector numbers for the track. If there is a bad 
sector and it is desired for the controller to just 
skip over it, then the bad block mark for that sec- 
tor position should be set to 80i6 and the sector 
number for that sector should be set to FFi6. If it 
is desired to map the bad sector then the bad 
block mark for that sector should be set to 80i6 
and the sector number for that sector should be 
set to the correct value for that position in the 
interleave table. The R and U options should be 
set in the set parameter and load parameter block 
commands. A write ID command then places the 
relocation information for that sector onto the 
drive. 


The interleave table format is: 

• BYTE 0: 1st sector’s block mark 

(00i6 or 80i6) 

• BYTE 1 : 1st sector’s sector number 


• BYTE 2: 2nd sector’s block mark 

(00i6 or 80i6) 

• BYTE 3: 2nd sector’s sector number 


• BYTE 2n: nth sector’s block mark 

(OOie or 80i6) 

• BYTE 2n+1 : nth sector’s sector number 


Command Flow: 


• MICRO: 1. 

2. 


3. 


4. 

5. 

6. 

WD42C22C: 7. 


8 . 


Set DRWB = 1 (bit 2) in the 
buffer manager control regis- 
ter (37i6) 

Load the starting address of 
the interleave table into the 
disk buffer pointer registers 
(34i6&35i 6 ). 

Set ECCM = 0 (bit 7) and 
DDRQ = 1 (bit 6) in the DIR 
write register (3Fi6) and 
MAC = 1 (bit 3) in the drive 
interface control register 
(3Bi6) to disable DRQI, if 
desired. 

Set ADBP = 1 (bit 0) in the 
buffer manager control reg- 
ister (37i6). 

Set MAC = 0 in the buffer 
control register. 

Issue format command to 
WD42C22C. 

Write FF to the alternate 
sector number register 
(3Ci6). Abort if drive not 
ready or write fault. 

(If DRQI is enabled) 

Activate BDRQ signal to buff- 
er manager and DRQI to 
microcontroller. Wait for 
BRDY signal indicating trans- 
fer of buffer pointer. Wait for 
leading edge of index. 


• MICRO: Set RDQI (bit 1) in the inter- 

face control register (38i6). 


• WD42C22C: 9. 

10 . 


Write gap. 

Write sector ID using para- 
meters in task register file 


325 
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• MICRO: 


and buffer memory. Data 
bytes are FF. 

1 1 . Decrement sector count reg- 
ister. If sector count = 0, then 
go to step 12, else go to 
step 9. 

1 2. Write Gap until leading edge 
of index pulse. 

1 3. De-assert Write Gate. 

14. Set DCI (bit 3) in the inter- 
face sta tus register (38i6). 
MCINT asserted. 

1 5. Read disk controller status 
register (27i6) and error 
register (21 1 6). 


Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
activated. 


The data placed in the gaps comes from an inter- 
nal register loaded during the load parameter 
block command. The data placed into the pads 
comes from another internal register loaded 
during the load parameter block command. 

After the task register file has been loaded with 
the desired format parameters and the block 
marks and sector number loaded into the buffer, 
then the command register is loaded with the for- 
mat single sector command. When the BRDY pin 
is activated by the buffer manager, the controller 
then looks for the start of the desired sector. The 
bad block mark and sector number are read from 
the buffer. The data field is written with FF. CRC is 
automatically computed and written if in CRC 
mode. If in ECC mode, ECC check bytes are 
automatically computed and written after the data 
field. The number of ECC check bytes is deter- 
mined by the E bit in the set parameter command. 


Note 

Gap length written on disk is 3 bytes longer than 
gap value specified in sector number register. 


The data for the buffer is: 

• BYTE 0: bad block mark (00i6 or 80i6) 

• BYTE 1 : sector number of formatted sector. 


4.4.7 FORMAT SINGLE SECTOR 


Command Flow: 


This command formats one sector using 
parameters loaded in the task register file and in 
buffer memory. This command only applicable to 
hard sector mode. 

WRITE GATE is turned on and off within 4 bit 
times after index or sector if NRZ mode is 
selected or within 6 bit times otherwise. The W 
option controls the state of WRITE GATE over the 
gaps. Setting W to 1 turns off WRITE GATE over 
the gaps. 

Cylinder, head, and sector size numbers are 
taken from the task register file. Good block/bad 
block marks and sector number are taken from 
buffer memory. The physical sector position to be 
formatted is specified by the sector count register. 
If sector count = 1, then the first sector after index 
is formatted. For sector count = 2, the second 
sector after index is formatted, and so on. The 
lengths of GAP 1 and GAP 3 are loaded into the 
sector number register. The length of the ID PLO 
sync field is loaded into the PLO length register. 


• MICRO: 


1 . Set DRWB = 1 (bit 2) in the 
buffer manager control regis- 
ter (37ie). 

2. Load the starting address of 
the interleave table into the 
disk buffer pointer registers 
(34i6&35ie). 

3. Set ECCM=0 (bit 7) and DDRQ 
=1 (bit 6) in the DIR write reg- 
ister (3Fi6) and MAC=1 (bit 

3) in the drive interface con- 
trol register (3Bi6) to dis- 
able DRQI, if desired. 

4. Set ADBP = 1 (bit 0) in the 
buffer manager control regis- 
ter (37ie). 

5. Set MAC=0 in the drive inter- 
face control register. 

6. Issue format single sector 
command to WD42C22C. 


• WD42C22C: 7. Write FF to the alternate sec- 
tor number register (3Ci6). 
Abort if drive not ready or 
write fault. 

8. (If DRQI is enabled) 

Activate BDRQ signal to buff- 
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er manager and DRQI to 
microcontroller. Wait for BRDY 
signal indicating transfer of 
buffer pointer. Wait for leading 
edge of index. 

• MICRO: 

Set RDQI (bit 1 ) in the inter- 
face control register (38i6). 

• WD42C22C: 9. 

Decrement sector count. If 
sector count = 0 go to 1 1 , 
else go to 10. 

10. 

Wait for SECTOR pulse, then 
go to 9. 

11. 

Assert WRITE GATE. Write 
gap. 

• WD42C22C:12. 

Write sector ID using para- 
meters in task register file and 
buffer memory. Data bytes 
are FF. 

13. 

Write gap until leading edge 
of SECTOR pulse. 

14. 

De-assert Write Gate. 

15. 

Set DCI (bit 3) in the inter- 
face status register (38i6). 
MCINT asserted. 

• MICRO: 16. 

Read disk controller status 
register (27i6) and error 
register (21 ie)- 


Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
activated. 

4.4.8 COMPUTE CORRECTION 

This command is used to compute the pattern and 
location of a single burst error. It is used after a 
read sector command has detected a data field 
ECC error. The compute correction command 
first writes the four or seven syndrome bytes into 
the buffer. It then processes the syndrome bytes 
to compute the error pattern and error location. 
The error location and error pattern bytes are writ- 
ten into the buffer. Either four or seven error pat- 
tern bytes are written to the buffer depending on 
the ECC length selected. The error pattern bytes 
are automatically byte aligned. 

The P option is used to control whether or not the 
error pattern bytes are calculated. If P = 0, then 
the error pattern bytes are calculated and sent to 


the buffer. If P = 1 , then the error pattern bytes are 
not calculated. Only the syndrome byte is trans- 
ferred to the buffer. This option facilitates firmware 
algorithms that require a matching syndrome 
before a correction is made. In this case, the 
firmware calculates the error pattern, corrects the 
error, and saves the syndrome after initially 
detecting the error. Then, the firmware dumps and 
compares the syndrome on the second read of 
the same sector. An ECC error can now be cor- 
rected in one revolution of the disk compared to 
three revolutions required by earlier WD1010 and 
WD2010 based controllers. 

The error pattern and error location bytes are not 
valid if the error is found to be uncorrectable. An 
uncorrectable error is indicated by the appropriate 
bits in the status and error register. 

The buffer contents contains the following infor- 
mation: 

• SYNDROME BYTE (MSB) 

• SYNDROME BYTE 

• SYNDROME BYTE 

• SYNDROME BYTE (LSB if 4 byte ECC) 

• SYNDROME BYTE (if 7 byte ECC) 

• SYNDROME BYTE (if 7 byte ECC) 

• SYNDROME BYTE (LSB if 7 byte ECC) 

• BYTE OFFSET (MSB) 

• BYTE OFFSET (LSB) 

• ERROR PATTERN (MSB) 

• ERROR PATTERN 

• ERROR PATTERN 

• ERROR PATTERN (LSB if 4 byte ECC) 

• ERROR PATTERN 

• ERROR PATTERN 

• ERROR PATTERN (LSB if 7 byte ECC) 

If the byte offset is 0, then the first data byte of the 
sector should be exclusive OR’ed with the first 
error pattern byte (MSB). Each succeeding data 
byte exclusive OR’ed with the succeeding error 
pattern byte until the fourth data byte is exclusive 
OR’ed with the fourth error pattern byte (LSB). 
Exclusive OR the first two error pattern bytes for 5 
bit spans. Exclusive OR the first three error pat- 
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tern bytes for 11 bit spans. Exclusive OR the first 
four error pattern bytes for the 22 bit span. 

Command Flow: 


•MICRO: 1. 

2 . 


3. 


4. 

5. 

6. 

• WD42C22C: 7. 


8. 


• MICRO: 

• WD42C22C: 9. 


10. 


11. 


Set DRWB=0 (bit 2) in the 
buffer manager control regis- 
ter (37i6). 

Load the starting address of 
the error correction data buff- 
er into the disk buffer pointer 
registers (34i6 & 35i6). 

Set ECCM=0 (bit 7) and DDRQ 
=1 (bit 6) in the DIR write reg- 
ister (3Fi6) and MAC=1 
(bit 3) in the drive interface 
control register (3Bi6) to 
disable DRQI, if desired. 

Set ADBP=1 (bit 0) in the 
buffer manager control regis- 
ter (37ie). 

Set MAC=0 in the drive inter- 
face control register. 

Issue compute correction 
command to WD42C22C. 

Write FF to the alternate sec- 
tor number register (3Ci6). 
Abort if drive not ready or 
write fault. 

(If DRQI is enabled) 

Activate BDRQ signal to buff- 
er manager and DRQI to 
microcontroller. Wait for BRDY 
signal indicating transfer of 
buffer pointer. 

Set RDQI (bit 1) in the inter- 
face control register (38i6). 

Transfer contents of the four 
(or seven) byte ECC register 
to buffer, most significant byte 
first. 

Clock the ECC register. Stop 
if correctable pattern found or 
if number of clocks exceeds 
sector size. If number of 
clocks exceeds sector size, 
set error bit of status register 
and ECC error of error regis- 
ter. 

Transfer byte count to buffer 
(2 bytes). Transfer 4 bytes of 
error pattern to buffer if 4 
byte ECC. Transfer 7 bytes 
of error pattern 7 byte ECC. 


1 2. Set DCI (bit 3) in the interface 
status r egister (38i6). 

MCINT asserted. 

• MICRO: 13. Read disk controller status 

register (27i6) and error 
register (21 1 6). 

Error Flags: 

• CRC/ECC flag set if data field error length ex- 
ceeds correction span. 

NOTE 

Default 11 bit correction span after master reset if 
7-byte ECC or 5 bit correction span if 4-byte ECC. 

4.4.9 SET PARAMETER 

The E bit is used to select either 4 byte or 7 byte 
sector extension for read long and write long com- 
mands. It also selects either a 4 or 7 byte internal- 
ly generated ECC. A 7 byte sector extension and 
7 byte ECC are the default after a master reset 
(due to RLL default). If E is 0, then a 4 byte sector 
extension and 4 byte ECC are selected if MFM or 
NRZ mode. If E is 1, then a 7 byte sector exten- 
sion and 7 byte ECC are selected. 

The H bit selects either 3 or 4 head select bits in 
the SDH register. If H=0, then 3 head select bits 
are written or compared in the ID fields on the 
drive. If H=1 , then 4 head select bits are written or 
compared in the ID fields on the drive. The 
default after master reset is 3 head select bits. 

The S bit is used to select either a 5 bit or 11 bit 
correction span if 4 byte ECC and an 11 bit or 22 
bit correction span if 7 byte ECC. An 11 bit correc- 
tion span for 7 byte ECC is the default parameter 
following master reset. If S is 0, then a 5 bit cor- 
rection span is selected if 4 byte ECC, 11 bit 
correction span if 7 byte ECC. If S is 1, then an 
11 bit correction span is selected if 4 byte ECC, 
22 bit correction span if 7 byte ECC. 

The Z bit is used to select MFM, RLL, or NRZ 
mode. If K=0 in the load parameter block com- 
mand, then RLL coding is selected regardless of 
the state of Z. If Z is 0 and K is 1, then MFM 
coding is selected. If Z is 1 and K = 1, then NRZ 
coding is selected. 

The R option is used to enable relocation ID 
searches. If R=1 for read and write sector com- 


AD VANCE D INFORMATION 12/4/90 


33-49 





WD42C22C 


BUFFER MANAGER ORGANIZATION 


mands and a bad block mark is detected in the 
desired sector’s ID, then the WD42C22C sear- 
ches for a special ID field containing relocation 
information immediately after the desired sector’s 
ID. This special ID field is placed using the write 
ID command. When the R option is used, then the 
U option must be set to 1 in the load parameter 
block command. 

Command Flow: 

• MICRO: 1 . Issue set parameter com- 

mand to WD42C22C. 

• WD42C22A: 2. Write FF to the alternate sec- 

tor number register (3Ci6). 
Abort if drive not ready or 
write fault. 

3. Set or reset internal para- 
meter flip-flop. 

4. Set DCI (bit 3) in the interface 
status r egister (38i6). 

MCINT asserted. 

• MICRO: 5. Read disk controller status 

register (27i6) and error 
register (21 16). 

Error Flags: 

• None. 

4.4.10 LOAD PARAMETER BLOCK 

The D bit is used to indicate the sectoring mode. 
If D = 0, the default after a master reset, then soft 
sector mode is selected. If D = 1 , then hard sector 
mode is selected. In hard sector mode, the PLO 
length register is transferred to the internal GAP 
length register during the load parameter block 
command. This GAP register is used to control 
the delay from INDEX/SECTOR to READ GATE 
on. 

The K bit selects the data interface mode. If K=0, 
the default after a reset, then RLL mode is 
selected. If K=1 , then the interface is either MFM 
or NRZ as selected by the set parameter com- 
mand. 

The U bit selects the sector size options. If 11=0, 
then the sector sizes are 128, 256, 512, and 1024 
depending on the contents of the SDH register. If 
11=1, then the sector size is defined by the user. 
The cylinder registers are loaded with the desired 


sector size prior to issuing the load parameter 
block command. 

In addition, the load parameter block command is 
used to load several internal parameters for for- 
mat, read, and write commands. The task file is 
loaded with these parameters prior to the start of 
the command. The registers loaded and the cor- 
responding parameters are: 


REGISTER 

PARAMETER 

21 

Delay from INDEX/SECTOR to 
RG 

22 

Data written in GAPS 

23 

Data written in PADS 

24 

LS byte of sector size, LS byte 
of offset for write ID command 

25 

3 MS bits of sector size, 3 MS 
bits of offset for write ID com- 
mand 


Command Flow: 

• MICRO: 1 . Load parameters into task file. 

2. Issue load parameter block 
command to WD42C22C. 

• WD42C22C: 3. Write FF to the alternate sec- 

tor number register (3Ci6). 
Abort if drive not ready or 
write fault. 

4. Set or reset internal parameter 
flip-flop. 

5. Copy cylinder registers to in- 
ternal sector size register. 
Copy PLO register to internal 
GAP register. Copy sector 
count register to internal GAP 
data register. Copy sector 
number register to internal 
PAD data register. 

6. Set DCI (bit 3) in the interface 
status r egister (38i6). 

MCINT asserted. 

• MICRO: 7. Read disk controller status 

register (27 1 6) and error 
register (21 16). 

Error Flags: 

• None. 


33-50 


ADVANCED INFORMATION 12/4/90 






BUFFER MANAGER ORGANIZATION 


WD42C22C 


4.4.11 SLEEP 

The sleep command places the WD42C22C in a 
low power standby mode. When the sleep com- 
mand is issued, the disk controller section clocks 
are disabled and only the buffer manager and 
host interface logic is enabled. The disk controller 
can be brought out of the sleep mode by setting 
RDC = 1 (bit 7) in the disk controller control 
register (3Bi6) or by resetting the entire 
WD42C22C. The microcontroller should NEVER 
attempt to read or write the drive controller task 
file (registers 21 16 through 27i6) while the drive 
controller is in the sleep mode. 

Command Flow: 

• MICRO: 1 . Issue sleep command to 

WD42C22C. 


and the sector size. The sector size should be 
programmed to 1 less than the number of bytes to 
be dumped for the sector. 

The B option controls the sync byte and CRC 
preset. If B = 0, then the sync byte is assumed to 
FE and the CRC is preset to all zeroes. If B = 1, 
then the sync byte is assumed to be A1 and the 
CRC is preset to all ones. 

The L option selects either CRC or no CRC 
checking. If L = 0, then CRC is checked. If L = 1 , 
then either four or seven check bytes are trans- 
ferred to the buffer depending on the extension 
selected by the set parameter command. If L = 1 , 
then I should also be set to 1. B does not affect 
the L option. 


• WD42C22C: 2. Write FF to the alternate sec- 

tor number register (3Ci6). 

3. Disable drive controller clocks. 

• MICRO: 4. Wake up disk controller by 

setting RDC=1 or by resetting 
the WD42C22C. 

Error Flags: 

• None. 

4.4.12 DUMP 

The dump command sends data off the media 
regardless of matching ID fields and regardless of 
the format. The command can dump an ID field, a 
data field, or both. Dump retrieves all the ID fields 
from index to index to determine the interleave. 
Dump can also read the ESDI standard defect list. 
The command dumps data starting at the first 
byte after the A1 sync byte for WD format or the 
first byte after the FE sync byte for ESDI format. 
This command can only do multisector dumps in 
hard sector mode. 


The PLO register controls the read gate delay for 
the first sector. READ GATE turns on x + 5 + CL 
bytes after the index pulse. Read gate for sub- 
sequent sectors is controlled as in normal read 
and write commands. 

Use the dump command to read an ESDI defect 
list as follows: 

1 . Set PLO register = read gate delay - 5. 

2. Set sector size = 255 for 256 byte sector. 

3. Issue A1 command. 

Use the dump command to dump the track inter- 
leave for WD format as follows: 

1 . Set PLO register = read gate delay - 5. 

2. Set sector size = 4. 

3. Set sector count = number of sectors per 
track. 


The command is assumed to be a multisector 
command. To read just one sector as in an ESDI 
defect list read, then the sector count must be set 
to one. There are three options. 

The I option controls the number of fields that are 
dumped for each sector. If I = 0, then two fields 
(ID and data) are dumped for each sector. If I = 1 , 
then only one field is dumped for each sector. The 
type of field is determined by the read gate delay 


4. Issue AD command. 

Use the dump command to dump all the data 
fields on a track for WD format as follows: 

1 . Set PLO register = read gate delay to start of 
data PLO - 5. 

2. Set sector size = actual number of bytes per 
sector. 
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3. Set sector count = number of sectors per 
track. 

4. Issue AF command or AB command. 

In this case, the F8 second data sync byte is 
transferred to the buffer. The buffer requires one 
extra byte per sector. 

One BRDQ interrupt occurs at the very beginning 
of the command. Therefore, the buffer must be 
contiguous and large enough to handle all the 
dumped sectors. 

Command Flow: 

• MICRO: 1 . Set DRWB = 0 (bit 2) in the 

buffer manager control regis- 
ter (37i6). 

2. Load the starting address of 
the buffer into the disk buffer 
pointer register (34i6 & 35i6). 

3. Set ECCM = 0 (bit 7) and 
DDRQ = 1 (bit 6) in the DIR 
write register (3Fi6) and 
MAC = 1 (bit 3) in the drive 
interface control register 
(3Bi6) to disable DRQI, 

if desired. 

4. Set ADBP = 1 (bit 0) in the 
buffer manager control regis- 
ter (37ie). 

5. Set MAC = 0 in the drive inter- 
face control register. 

6. Issue dump command to 
WD42C22C. 

• WD42C22C 7. Write FF to alternate sector 

number register (3Ci6). 

Abort if drive not ready or 
write fault. 

8. (If DRQI is enabled) 

Activate BDRQ signal to buff- 
er manager and DRQI to 
microcontroller. Wait for BRDY 
indicating transfer of buffer 
pointer. 


• MICRO: Set RDQI (bit 1) in the inter- 

face control register (38i6). 

• WD42C22C: 9. Wait for index. 

10. If 1=1 , then go to 1 2 else go 
to 11. 

1 1 . Search for sync byte. When 
found, dump 5 data bytes 
into buffer. 

1 2. Search for sync byte. When 
found, dump programmed 
number of bytes into the buff- 
er. 

13. Decrement sector count. If 
sector count = 0, then go to 
14 else go to step 10. 

1 4. Set DCI (bit 3) in the interface 
status r egister (38i6). 

MCINT asserted. 

• MICRO: 1 5. Read disk controller status 

register (27i6) and errror 
register (21 16 >- 

Error Flags: 

• Drive not ready and aborted command set if 
drive not ready. 

• Write fault and aborted command set if WF pin 
activated. 

• ID not found set if I = 0 and index detected 
while searching for an ID field or if CRC of ID 
field doesn’t zero. 

• Data AM not found is set and index is 
detected while searching for a data field. If 1=0 
or when searching for either an ID or data field 
when 1 = 1. 

• Data CRC if the data field CRC doesn’t zero 
when I = 0 or if either an ID or data field CRC 
doesn’t zero when 1 = 1. 
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ELECTRICAL AND TIMING SPECIFICATIONS 


WD42C22C 


5.0 ELECTRICAL AND TIMING 
SPECIFICATIONS 

5.1 MAXIMUM RATINGS 

Vcc with respect to Vss (ground) 

Max voltage on any pin with respect to Vss 

Operating temperature (Ta) 

Storage temperature 

NOTE 

Maximum limits where permanent device damage 
occurs. Continuous operation at these limits is not 
intended and should be limited to those conditions 
specified in the DC operating characteristics. 

5.2 DC OPERATING CHARACTERISTICS 


SYMBOL 

CHARACTERISTIC MIN 

MAX 

UNITS 

CONDITIONS 

IlL 

Input Leakage 

±10 

HA 

Vin = 0.4 to Vcc 

loz 

Tri-state and open drain 
output leakage 

±10 

ma 

Vout = 0.4 TO Vcc 

VlH 

Input High Voltage 2.0 


V 


VlL 

Input Low Voltage 

0.8 

V 


VOH 

Output High Voltage 2.4 


V 

Iout=-800|liA 

VOL 

Output Low Voltage 

0.4 

V 

loirr=2.0mA 

Icc 

Supply Current 

100 

mA 

All outputs open. 

Ices 

Supply Current (Standby 
Mode) 

25 

mA 

All inputs at Vdd or Vss, disk con- 
troller sleep mode, 15 MHz crystal. 


TABLE 14. DC OPERATING CHARACTERISTICS 


For pins 75 thru 82, 40 thru 42, 44 thru 48, 74, 8 
(HDO thru HD15, INTRQ, DREQ): 


SYMBOL 

CHARACTERISTIC 

MIN MAX UNITS 

CONDITIONS 

VOH 

Output High Voltage 

2.4 V 

louT=-5mA 

VOL 

Output Low Voltage 

0.4 V 

lo(JT=12mA 


+5 V ± 5% 

-0.5V to 5.5 

0°C (32°F) to 70°C (158°F) 

-55°C (-67° F) to 125°C (257°F) 


For pin 8 (IOCS16, AT PIO mode only): 


SYMBOL 

CHARACTERISTIC 

MIN MAX 

UNITS 

CONDITIONS 

VOL 

Output Low Voltage 

0.4 

V 

lo=20.0mA 


For pins 10, 11 

and 12 (WD, EARLY, LATE): 


SYMBOL 

CHARACTERISTIC 

MIN MAX UNITS 

CONDITIONS 

VOH 

Output High Voltage 

2.4 

lo=-800|^A 

VOL 

Output Low Voltage 

0.4 V 

lo=6.0mA 
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ELECTRICAL AND TIMING SPECIFICATIONS 


For Din 22 (RESET 






SYMBOL 

CHARACTERISTIC 

MIN MAX 

UNITS 

CONDITIONS 

VOL 

Output Low Voltage 

0.4 

V 

lo=48.0 mA 


For pins 59-73 (BA0-B14 




SYMBOL 

CHARACTERISTIC 

MIN MAX 

UNITS 

CONDITIONS 

IPD 

Pulldown Current in 
read config. mode 

40 160 

hA 

Vout=2.4V 

For pins 5, 6, 

9 (HRE, HWE, and DACK in slave 



host mode) and pins 40-42, 44-48 (HD8 through 



HD15 in 8-bit host mode): 




SYMBOL 

CHARACTERISTIC 

MIN MAX 

UNITS 

CONDITIONS 

Ipu 

Pullup Current 

100 2000 

|liA 

Vout=0.4 V, Vdd=5.25 V 

For pin 38 (XTALIN when driven by external osc.): 


































ELECTRICAL AND TIMING SPECIFICATIONS WD42C22C 


V 5.0 

V 

/ \ 

* V 

RST2 

Vrsti^-j. 

7 


< RST3 

— v RST4 





RESET 


4 I DQTI 

1 

0.0 _ / 


* no 1 L 

(Refer to MISC. timings.) 

l\^ 



FIGURE 6. POWER QUALIFIED RESET VOLTAGE THRESHOLD 


For p i ns 1-7 , 9, 15, 16, 20 , 2 1, 23 , 25- 3 5, 40-42, 44-48 , 51-5 8, 59-73, 74, 75-82 (HA0-HA2, HA9, HRE : 
HWE, HCS, DACK, INDEX, SCT, WF, DRDY, RESET, ALE, MRE, MWE, AD0-AD7, HD8-HD15, BD0- 
BD7, BA0-BA15, INTRQ, HD0-HD7) 



For pin 84 (Vnn) 

1 SYMBOL CHARACTERISTIC MIN MAX UNITS CONDITIONS 
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ELECTRICAL AND TIMING SPECIFICATIONS 


5.3 AC TIMING CHARACTERISTICS 
NOTE 

Load capacitance=50 pF each for all other out- 
puts. Timings must be derated for larger load 
capacitances. 

For pins 14, 16, 17, 19 (WC, DRUN, RD, RC ): 

SYMBOL CHARACTERISTIC MIN MAX UNITS 


CONDITIONS 




HD7-HD0 


IOCS16 
(AT only) 


FIGURE 7. AT/XT HOST PROGRAMMED I/O WRITE TIMING 


NOTE 

A write occurs during the overlap of HCS and 









ELECTRICAL AND TIMING SPECIFICATIONS 


WD42C22C 


5.3.1 AT/XT HOST PROGRAMMED I/O WRITE 
TIMING 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

CONDITIONS 

tASW 

Address Setup to 

HWE Low 

30 


ns 


tcsw 

HCS Setup to HWE 
Low 

10 


ns 


tDS 

Data Setup to HWE 
High 

30 


ns 

Port 0 only. 

tWE 

HWE Pulse Width 

75 


ns 

Port 0 only. 

tDS 

Data Setup to HWE 
High 

50 


ns 

All other ports. 

tWE 

HWE Pulse Width 

100 


ns 

All other ports 

tDH 

Data Hold from 

HWE High 

15 


ns 


tAHW 

ADDR Hold from HWE 
High 

20 


ns 


tCHW 

HCS Hold from HWE 
High 

10 


ns 


tWER 

HCS and HWE Inact- 

20 


ns 



ive 





twCY 

Write Cycle Time 

125 


ns 

PortO, XTAL>16 MHz 



2*X 



PortO, XTAL<16MHz(X=txTAL) 

twCY 

Write Cycle Time 

150 


ns 

All other ports 

tcicsv 

IOCS16 valid from 

HCS 


30 

ns 


tAICSV 

IOCS 16 valid from 
address 


40 

ns 


tcicsi 

IOCS 16 inactive from 
HCS 


35 

ns 

Test circuit 1. 

tAICSI 

IOCS16 inactive from 
address 


45 

ns 

Test circuit 1. 


TABLE 15. AT/XT HOST PROGRAMMED I/O WRITE TIMING 


IOCS16 



FIGURE 8. TEST CIRCUIT 1 
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ELECTRICAL AND TIMING SPECIFICATIONS 


WD42C22C 


5.3.2 AT/XT HOST PROGRAMMED I/O READ 
TIMING 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

CONDITIONS 

tASE 

Address Setup to HRE 
Low 

30 


ns 


tCSE 

HCS Setup to HRE 

Low 

10 


ns 


tDAC 

Data Valid from HRE 


60 

ns 

Port 0, 8-bit. 


Low 


70 


PortO, 16-bit. 




100 


All other ports. 

tRE 

HRE Pulse Width 

75 


ns 

PortO 



100 



All other ports 

tDOH 

Data Hold from HRE 
High 

5 


ns 


tHDTS 

Data Tri-state from 

HRE 


50 

ns 


tHLD 

Address, HCS Hold 
from HRE High 

10 


ns 


tRDR 

HCS and HRE Inact- 
ive 

20 


ns 


tRDCY 

Read Cycle Time 

125 


ns 

PortO, XTAL>16 MHz 


2*X 



Port 0, XTAL<16 MHz (X=txTAi_) 

tRDCY 

Read Cycle Time 

150 


ns 

All other ports. 

tcicsv 

IOCS 16 Valid from 

HCS 


30 

ns 


tAICSV 

IOCS16 Valid from 
Address 


40 

ns 


tcicsi 

IOCS16 Inactive from 
HCS 


35 

ns 

Test circuit 1 

tAICSI 

IOCS16 Inactive from 
Address 


45 

ns 

Test circuit 1 


TABLE 16. AT/XT HOST PROGRAMMED I/O READ TIMING 
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ELECTRICAL AND TIMING SPECIFICATIONS 


WD42C22C 


SYMBOL 

CHARACTERISTIC 

MIN MAX 

UNITS 

CONDITIONS 

tDLQL 

DACK Low to DRQ 
Low 

100 

ns 

BDEN=0 

tWHQL 

HWE High to DRQ 

4*X 

ns 

BDEN=1 . First transfer count throt- 


Low 

+100 


tie. (X=tXTAL) 

tDK 

DMA Cycle 

100 

ns 

XTAL=20MHz 



2*X 


Any XTAL (X=txTAL) 

tDLWL 

DACK Low to HWE 
Low 

0 

ns 


tWR 

HWE Pulse Width 

80 

ns 


tDVWH 

Data Valid to HWE 
High 

30 

ns 


tWHDH 

HWE High to DACK 
High 

0 

ns 


tWHDI 

HWE High to Data In- 
valid 

15 

ns 


tDWI 

DACK and HWE In 
active 

20 

ns 



TABLE 17. AT/XT DMA WRITE TIMING 


2S 
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ELECTRICAL AND TIMING SPECIFICATIONS 


WD42C22C 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

CONDITIONS 

tDLQL 

DACK Low to DRQ 
Low 


100 

ns 

BDEN=0 

tRHQL 

HRE High to DRQ 


4*X 

ns 

BDEN=1 . First TC throttle. 


Low 


+100 


(X=tXTAL) 

tDK 

DMA Cycle 

100 


ns 

XTAL=20MHz 



2*X 



Any XTAL (X=t X TAL.) 

tDLRL 

DACK Low to HRE 

Low 

0 


ns 


tRD 

HRE Pulse Width 

80 


ns 


tRLDV 

HRE Low to Data 


60 

ns 

8-bit mode 


Valid 


70 


16-bit mode 

tRHDH 

HRE High to DACK 
High 

0 


ns 


tDHRH 

Data Hold from HRE 
High 

5 


ns 


tRHDI 

HRE High to Data tri- 
state 


50 

ns 


tDRI 

DACK and HRE Inact- 
ive. 

20 


ns 



TABLE 18. AT/XT DMA READ TIMING 
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5.3.5 SLAVE HOST WRITE TIMINGS 



SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

CONDITIONS 

tWHWL 

Address Port Write to 
Data Write Recovery 
Time 

120 

10000 

ns 


tMWHAL 

MWE to HALE Delay 


150 

ns 


tAVAL 

HD Address Setup to 
HALE Low 

40 


ns 

AD setup to MWE (tADVWH)=130 ns 

tALAI 

HD Address Hold From 
HALE low 

0 


ns 


tALWL 

HALE Low To HWE 

Low 

90 


ns 


tDVWH 

HD Valid to HWE High 

70 


ns 

AD setup to MWE (tADVWH)=130 ns 

tWHDI 

HD Inactive from HWE 

0 


ns 


tMWHWL 

MWE Low to HWE Low 


150 

ns 


tMHWH 

MWE High to HWE 

High 


150 

ns 



TABLE 19. SLAVE HOST WRITE TIMING 
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ELECTRICAL AND TIMING SPECIFICATIONS 


WD42C22G 


5.3.6 SLAVE HOST READ TIMINGS 



SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

CONDITIONS 

tWHALH 

Address Port Write to 
ALE High Read 
Recovery Time 

400 

10000 

ns 

tHRLDV=210 ns 

tMWHAL 

MWE to HALE Delay 


150 

ns 


tMWHRE 

MWE to HRE Delay 


150 

ns 


tAVAL 

HD Address Setup to 
HALE Low 

40 


ns 

AD setup to MWE (tADVWH)=130 
ns. 

tALAI 

HD Address Hold from 
HALE Low 

0 


ns 


tHDSA 

HD Data Setup to ALE 
High 

40 


ns 


tHDHA 

HD Data Hold from 
ALE High 

40 


ns 


tMRHRH 

MRE Low to HRE High 
Delay 

0 


ns 


tHRLDV 

HRE Low to HD Data 
Valid Delay 




tHRLDV is a function of the slave 
peripheral device and only affects 
tWHALH- tWALH = tMWHRE + tHRLDV 
+ tHDSA 


TABLE 20. SLAVE HOST READ TIMING 
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WD42C22C 


5.3.7 SLAVE HOST DMA WRITE TIMING 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

CONDITIONS 



BIN 02 

BIN 02 





BIN 03 

BIN 03 





BIN 05 

BIN 05 



tswi 

RCS Low to HWE First 

0 


ns 



Transfer of Burst 

0 






0 




tSW2 

HD Valid to HWE Rising 

30 


ns 




30 






30 




tsW3 

HWE Rising to HD In- 

15 


ns 



valid 

15 






15 




tSW4 

HWE Cycle Time 

200 


ns 

tXTAL < tSW4 / 


200 



2 



100 




tSW5 

HWE Low Pulse Width 

80 


ns 




80 






30 




tSW6 

HWE High Pulse 

30 


ns 




30 






30 




tSW7 

HWE Rising to DRQ Low 


4*X + 100 

ns 

Intermediate 



4*X + 100 


throttle. X = 




4*X + 50 


tXTAL 

tswio 

RCS Low to DREQ Low 


100 


Throttle when 




100 


transfer 




50 


count < 16 or 






single trans- 
fer mode 

tswn 

DACK Low to HWE Out 


60 

ns 

HSMB = 1 


Tri-state 


60 






60 




TABLE 21. SLAVE HOST DMA WRITE TIMING 


The following notes apply to Figure 15. 

NOTE 1 

SBIC guarantees no transfer here at 5 MB/s 
transfer rate. 

NOTE 2 

SBIC guarantees no transfer here at 10 MB/s 
transfer rate. 

NOTE 3 

SBIC guarantees no transfer here. 


Although 4 transfers may occur after the FIFO 
goes almost full at 10 MB/s and only 3 bytes 
remain at that time, the buffer manage guarantees 
that at least 1 additional transfer occurs out of the 
FIFO prior to the fourth host transfer after the al- 
most full condition. This guarantees that no over- 
run condition occurs. 


322 
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WD42C22C 


5.3.8 SLAVE HOST DMA READ TIMING 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

CONDITIONS 



BIN 02 

BIN 02 





BIN 03 

BIN 03 





BIN 05 

BIN 05 



tswi 

RCS Low to HD Valid 

0 


ns 



First Transfer of Burst 

0 






0 




tSW2 

HRE Rising to HD Valid 

5 

180 

ns 




5 

180 





5 

180 



tSW3 

RCS Low to First HRE 

140 


ns 



Rising Edge 

140 






100 




tSW4 

HRE Cycle Time 

200 


ns 

tXTAL < tSW4 / 



200 



2 



100 




tSW5 

HRE Low Pulse Width 

80 


ns 




80 






30 




tSW6 

HRE High Pulse 

30 


ns 




30 






30 




tSW7 

HRE Rising to DRQ Low 


4*X + 100 

ns 

Intermediate 




4*X + 100 


throttle. X = 




4*X + 50 


tXTAL 

tswio 

RCS Low to DREQ Low 


100 


Throttle when 




100 


transfer 




50 


count < 16 or 
single trans- 
fer mode 

tswn 

DACK Low to HRE Out 


60 

ns 

HSMB = 1 


Tri-state 


60 






60 




TABLE 22. SLAVE HOST DMA READ TIMING 


The following notes apply to Figure 1 6. Although 4 transfers may occur after the FIFO 

goes almost full at 10 MB/s and only 3 bytes 
NOTE 1 remain at that time, the buffer manage guarantees 

SBIC guarantees no transfer here at 5 MB/s that at least 1 additional transfer occurs out of the 
transfer rate. FIFO prior to the fourth host transfer after the al- 

NOTE 2 most full condition. This guarantees that no over- 

SBIC guarantees no transfer here at 10 MB/s run condition occurs, 
transfer rate. 

NOTE 3 

SBIC guarantees no transfer here. 
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FIGURE 16. BUFFER RAM WRITE TIMING (INTERNAL OSCILLATOR) 


SYMBOL 

CHARACTERISTIC 

MIN 

Bin 02 

Bin 03 

Bin 05 

MAX 

UNITS 

CONDITIONS 

tADCY 

Address Cycle Time 

2*tXTAL-28 

2*tXTAL-35 

2*tXTAL-25 


ns 

Any XTAL 

tBASWH 

Addres Setup to 

2*t X TAL-40 


ns 

Any XTAL 


BWE High 

2*txTAL-55 

2*txTAL-35 




tBASWL 

Addres Setup to 

0.5*tXTAL-20 


ns 

Any XTAL 


BWE Low 

0.5*tXTAL-35 

0.5*tXTAL-20 




tBW 

BWE Pulse Width 

1 .5*tXTAL-30 

1 .5*txTAL-35 
1.5*tXTAL-25 


ns 

Any XTAL 

tBAHW 

Address Hold From 

5 


ns 

Any XTAL 


BWE High 

5 

5 




tDSWH 

Data Valid to BWE 

1.5*tXTAL-40 


ns 

Any XTAL 


High 

1.5*tXTAL-60 

1 .5*tXTAL-35 




tDHW 

Data Hold from 

10 


ns 

Any XTAL 


BWE High 

10 






10 




tDTSW 

Data Tri-state from 
BWE High 


50 

ns 

Any XTAL 


TABLE 23. BUFFER RAM WRITE TIMING (INTERNAL OSCILLATOR) 
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ELECTRICAL AND TIMING SPECIFICATIONS WD42C22C 



SYMBOL 

CHARACTERISTIC 

MIN 

20 MHz 

12 MHz 

UNITS 

CONDITIONS 

tADCY 

Address Cycle Time 

72 

ns 

Max XTAL 



125 



tADCY 

Address Cycle Time 

2*t X TAL-28 

ns 

Any XTAL 



2*txTAL-35 



tBASR 

Address Setup to 

72 

ns 

Max XTAL 


BOE High 

125 



tBASR 

Address Setup to 

2*t X TAL-28 

ns 

Any XTAL 


BOE High 

2*tXTAL-35 



tBR 

BOE Pulse Width 

45 

ns 

Max XTAL 



75 



tBR 

BOE Pulse Width 

1 .5*txTAL-30 

ns 

Any XTAL 



1 .5*tXTAL-45 



tBAHR 

Address Hold from 

0 

ns 

Any XTAL 


BOE High 

0 



tRDS 

Data Setup to 

5 

ns 

Any XTAL 


BOE High 

5 



tRDH 

Data Hold from 

10 

ns 

Any XTAL 


BOE High 

10 



tDHW 

Data Hold from 

10 

ns 



Address 

10 



• All timings in this table only are referenced to 



1 .5V levels. 





TABLE 24. BUFFER READ TIMING (INTERNAL OSCILLATOR) 
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WD42C22C 


5.3.11 BUFFER RAM WRITE TIMING (EXTER- 
NAL OSCILLATOR; XTAL = 8 to 20 MHz) 


SYMBOL 

CHARACTERISTIC 

MIN 

20 MHz 

12 MHz 

MAX 

UNITS 

CONDITIONS 

tADCY 

Address Cycle Time 

72 


ns 

Max XTAL 



125 




tADCY 

Address Cycle Time 

2*t X TAL-28 

2*txTAL-35 


ns 

Any XTAL 

tBASWL 

Address Setup to 

5 


ns 

Max XTAL/ 


BWE Low 

5 



50% XTAL 

tBASWL 

Address Setup to 

txCH-20 


ns 

Any XTAL 


BWE Low 

txcH-35 




tBASWH 

Address Setup to 

60 


ns 

Max XTAL 


BWE High 

105 




tBASWH 

Address Setup to 

2*t X TAL-40 


ns 

Any XTAL 


BWE High 

2*t X TAL-55 




tBW 

BWE Pulse Width 

55 


ns 

Max XTAL/ 



85 



50% XTAL 

tBW 

BWE Pulse Width 

tXTAL+txCL-30 

tXTAL+txCL-35 


ns 

Any XTAL 

tBAHW 

Address Hold from 

5 


ns 

Any XTAL 


BWE High 

5 




tDSWH 

Data Valid to BWE 

35 


ns 

Max XTAL 


High 

60 




tDSWH 

Data Valid to BWE 

tXTAL+txCH-40 


ns 

Any XTAL/ 


High 

tXTAL+txCH-60 



%50 XTAL 

tDHW 

Data Hold from BWE 

10 


ns 

Any XTAL 


High 

10 




tDTSW 

Data tri-state from BWE 

50 

ns 

Any XTAL 


High 





• All timings in this table only are referenced to 




1.5 V levels except tDHW- 






TABLE 25. BUFFER RAM WRITE TIMING (EXTERNAL OSCILLATOR) 
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WD42C22C ELECTRICAL AND TIMING SPECIFICATIONS 



SYMBOL 

CHARACTERISTIC 

MIN 

20 MHz 

12 MHz 

UNITS 

CONDITIONS 

tADCY 

Address Cycle Time 

72 

ns 

Max XTAL/50% XTAL 



125 



tADCY 

Address Cycle Time 

2*tXTAL-28 

ns 

Any XTAL 



2*tXTAL-35 



tBASR 

Address Setup to 

72 

ns 

Max XTAL/50% XTAL 


BOE High 

125 



tBASR 

Address Setup to 

2*tXTAL-28 

ns 



BOE High 

2*tXTAL-35 



tBR 

BOE Pulse Width 

45 

ns 

Max XTAL/50% XTAL 



75 



tBR 

BOE Pulse Width 

tXTAL+txCH-30 ns 

Any XTAL 



tXTAL+tXCH-45 


tBAHR 

Address Hold from 

0 

ns 

Any XTAL 


BOE High 

0 



tRDS 

Data Setup to BOE 

5 

ns 

Any XTAL 


High 

5 



tRDH 

Data Hold from BOE 

10 

ns 

Any XTAL 


High 

10 



tDHW 

Data Hold from Ad- 

10 

ns 



dress 

10 



• All timings in this table referenced to 1 .5 V 



levels. 






TABLE 26. BUFFER RAM READ TIMING (EXTERNAL OSCILLATOR) 
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5.3.13 MICROPROCESSOR WRITE TIMING 
(INTEL BUS) 



FIGURE 20. MICROPROCESSOR WRITE TIMING (INTEL BUS) 


SYMBOL 

CHARACTERISTIC 

MIN 

UNITS 

CONDITIONS 

tAVAL 

Address Setup to ALE 

15 

ns 



Low 




tALAI 

Address Hold from ALE 

5 

ns 



Low 




tALEH 

ALE High Pulse Width 

30 

ns 


tADVWH 

Data Setup to MWE 

50 

ns 

HSMB=0 


High 

130 


HSMB=1 

tWHDI 

Data Hold from MWE 

5 

ns 



High 




tMWEL 

MWE Low Pulse Width 

75 

ns 


tADWL 

Address Valid to MWE 

55 

ns 



Low 




tWHLH 

MWE High to ALE High 

10 

ns 
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FIGURE 21. MICROPROCESSOR WRITE TIMING (MOTOROLA BUS) 


SYMBOL 

CHARACTERISTIC 

MIN 

UNITS 

CONDITIONS 

tAVAL 

Address Setup to AS 
Low 

15 

ns 


tALAI 

Address Hold from AS 

5 

ns 


tASH 

AS High Pulse Width 

30 

ns 


tADVDS 

Data Setup to DS Low 

50 

ns 

HSMB=0 



130 


HSMB=1 

tDSDI 

Data Hold from DS 

Low 

5 

ns 


tDSH 

DS High Pulse Width 
during Write 

75 

ns 


tWLDS 

R/W Low to DS High 

5 

ns 


tDSWH 

DS Low to R/W High 

20 

ns 


tADDS 

Address High to DS 
High 

55 

ns 


tDSAH 

DS Low to AS High 

10 

ns 
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FIGURE 22. MICROPROCESSOR READ TIMING (INTEL BUS) 


SYMBOL 

CHARACTERISTIC 

MIN 

MAX 

UNITS 

tAVAL 

Address Setup to ALE 
Low 

15 


ns 

tALAI 

Address Hold from ALE 
Low 

5 


ns 

tALEH 

ALE High Pulse Width 

30 


ns 

tRLDV 

Data Valid from MRE 
Low 


100 

ns 

tDHRH 

Data Hold from MRE 
High 

10 


ns 

tRHDI 

Data Tri-state from 

MRE High 


50 

ns 

tMREL 

MRE Low Pulse Width 

100 


ns 

tADAR 

Address Valid to MRE 
Low 

55 


ns 

tRHLH 

MRE High to ALE High 

10 


ns 
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5.3.16 MICROPROCESSOR READ TIMING 
(MOTOROLA BUS) 



FIGURE 23. MICROPROCESSOR READ TIMING (MOTOROLA BUS) 


SYMBOL CHARACTERISTIC MIN MAX UNITS 



TABLE 30. MICROPROCESSOR READ TIMING (MOTOROLA BUS) 
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5.3.17 WRITE DATA TIMING (MFM/RLL MODE; 
WC 5 to 15 MHz) 



FIGURE 24. WRITE DATA TIMING (MFM/RLL MODE) 


SYMBOL 

CHARACTERISTIC MIN 
20 MHz 
12 MHz 

MAX 

UNITS 

twc 

WC Pulse Width 

28 

500 

ns 



45 

500 


tWLE 

Early/Late Propagation 

3 

15 

ns 



3 

25 


tWD 

WD Propagation Delay 

3 

15 

ns 



3 

25 


tWCF 

WC Frequency 

1 

15 

MHz 



1 

10 
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5.3.18 WRITE DATA TIMING (NRZ MODE; WC 5 
to 15 MHz) 











wn 


/ 

/ 



\ 

\ / 

/ 


tWD * 


« tWD 




t WDWCO ► 








t WD ► 


« 1 WD 



WC 


/ 

/ 

\ 

s 

/ 

r 


\ / 




twCL 


twCH * 


! 





/ 

\ 



1 / 



/ 



WCOUT 

/ 



\ 

/ 


\ 

/ 


\ 





t WDWCO 






1 WCOH 

t WOOL 



o 

% 

Q 

5 

L 



FIGURE 25. WRITE DATA TIMING (NRZ MODE) 


SYMBOL 

CHARACTERISTIC 

MIN 

20 MHz 

12 MHz 

MAX 

UNITS 

tWCL 

WC Pulse Width Low 

20 

500 

ns 



27 

500 


tWCH 

WC Pulse Width High 

20 

500 

ns 



27 

500 


tWLE 

Early/Late Propagation 

3 

15 

ns 



3 

25 


tWD 

WD Propagation Delay 

3 

15 

ns 



3 

25 


twCF 

WC Frequency 

1 

22 

MHz 



1 

16.5 


twCOL 

WCOUT Pulse Width 

twCH - 5 


ns 


Low 

twCH - 9 



twCOL 

WCOUT Pulse Width 


tWCH + 5 

ns 


Low 


twCH + 9 


twCOH 

WCOUT Pulse Width 

twCH - 5 


ns 


High 

twCH - 9 



twCOH 

WCOUT Pulse Width 


twCH + 5 

ns 


High 


twCH + 9 


tWDWCO 

WD Prop Delay from 

-5 

+5 

ns 


WCOUT 

-8 

+8 



TABLE 32. WRITE DATA TIMING (MFM/RLL MODE) 
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5.3.19 READ DATA TIMING (MFM/RLL MODE; 
RC/WC 5 to 15 MHz) 



FIGURE 26. READ DATA TIMING (MFM/RLL) 


SYMBOL CHARACTERISTIC MIN MAX UNITS 

20 MHz 

12 MHz 

tRCP RC Pulse Width 27 500 ns 

45 500 

txi RC Transition to Next 5 ns 

Leading RD 10 

tx 2 Leading RD to Next RC 10 ns 

Transition 20 

tRD Read Data Pulse 20 tRCP ns 

Width 30 tRCP 

tDRN DRUN Low Pulse 25 ns 

Width 25 

tRCF RC Frequency 1 15 MHz 

1 10 


TABLE 33. READ DATA TIMING (MFM/RLL) 
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5.3.20 READ DATA TIMING (NRZ MODE; WC 5 
to 20 MHz) 



SYMBOL 

CHARACTERISTIC 

MIN MAX 
20 MHz 

12 MHz 

UNITS 

tRCP 

RC Pulse Width 

20 

500 

ns 



27 

500 


tRNS 

RD Setup to RC High 

7 


ns 



10 



tRNH 

RD Hold from RC High 7 


ns 



10 



tRCF 

RC Frequency 

1 

22 

MHz 



1 

16.5 



TABLE 34. READ DATA TIMING (NRZ MODE) 
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SYMBOL 

CHARACTERISTIC 

MIN 

MAX UNITS 

CONDITIONS 

tlDX 

Index Pulse Width 

100 

ns 


tSCT 

SCT Pulse Width 

100 

ns 


tlWG 

Index to write gate 

0 

4 WC periods 

Gap data=33 in RLL mode. Any 
gap data in MFM and NRZ. 

tWGWD 

Write gate to write data 

0 

4 WC periods 


tRSTI 

RESET in pulse width 
low 

24 

WC periods 


tMRW 

MR Trailing to Host 
Register Write 

2.4 

|XS 


Frcwc 

Difference of RC Fre- 
quency from WC Fre- 
quency 

-15% +15% 


tRSTL 

RESET Out Low Pulse 
Width during Power-up 

51.2 

ms 

XTAL=10 MHz 

tRSTL 

RESET Out Low Pulse 
Width during Power-up 

41.3 

ms 

XTAL=12.5 MHz 

tRSTL 

RESET Out Low Pulse 
Width during Power-up 

25.6 

ms 

XTAL=20 MHz 

tXTAL 

Clock Period 

50 

70 

125 ns 


tXCH 

Clock High Time 

25 

30 

ns 


txcL Clock Low Time 25 

30 

NOTE 

txTAL, txcH, and txcL timings at 2.5 V levels. 

ns 
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Repeated for Each Sector 


WG 

(during FORMAT) 


WG 

(during WRITE) 


42C22A 
FORMAT 
# BYTES 


GAP 4 GAP 1 

1 D PLO 

1 D 

1 D 

WRITE 

DATA PLO 

DATA DATA 

WS GAP 3 

ID PLO 

1 D 

n + 5 + CL 

X + 9 

7 

PAD 2 

SPICE 

1 

(ID 

PAD 

3 

1 n + 7 

X + 9 

7 


A 

1 

C L 

H 

S 

c 

c 

1 

D 

Y O 

E 

E 

R 

R 


E 

L W 

A 

c 

C 

C 


N 


D 

# 

1 

2 


T 

: 






X+ 12+/- 1 
(X = 0) 
X+13+/-1 
(X>0) 


NOTES 

1 . n = contents of sector number register during 
format command. 

2. CL = controller latency. 1/2 < CL < 1-1/2 byte 
times. 

3. x = contents of PLO register. ID PLO length is 
programmable during format command. Data 
PLO length is programmable during write com- 
mand. Data PLO length is 1 1 during format. Data 
PLO length is 1 2 ± 1 (or x + 1 3 + 1 ) during write if 
x = 0 (x > 0). 


A 

F 

128: 

2:CRC 

1 

8 

256: 

4:INT 



512: 

ECC 



1024: 

7:INT 



DATA 

ECC 


4. twGON = 

5. tWGOFFI 

6. tRGOFFI 

7. tRGOFF2 

8. tRGONI 

DRUN. 

9. tRGON2 = 


I DENT Definition: 

FE = Cylinders 0-255 
FF = Cylinders 256-51 1 
FC = Cylinders 512-767 
FD = Cylinders 768-1023 
F6 = Cylinders 1024-1279 
F7 = Cylinders 1280-1535 
F4 = Cylinders 1536-1791 
F5 = Cylinders 1792-2047 


17+1 bit times with respect to RD in. 
= 28 bit times with respect to WD out. 
= 9 ± 1 bit times with respect to RD in. 
= 9 ± 1 bit times with respect to RD in. 
= 19 + 1 bit times with respect to 


= 35 + 1 bit times with respect to RD in. 


FIGURE 29. SOFT SECTOR MFM/RLL TRACK FORMAT 
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Repeated for Each Sector 


AME 

(during Format) 

AME __j 

(during R/W) 

AMF 


WG 

(during FORMAT) 


WG 

(during WRITE) 


l RREC- 


* RGOFFf* 


1 RG0FF2 — r I* 


42C22A 
FORMAT 
# BYTES 


GAP 4 GAP 1 

1 D PLO 

1 D 

1 D 

WRITE 

DATA PLO 

DATA DATA 

WS GAP 3 

ID PLO 

1 D 

n + 7 + CL, 

X + 8 

7 

PAD 2 

| SPICE 

1 

(11) 

PAD 

3 

1 n + 9 

X + 8 

7 



/ / 

z ^ 

A 

1 C 

L 

HSCC 

X + 1 2 +/- 1 

A 

F 128: 2:CRC 

1 

D Y 

O 

E E R R 

(X = 0) 

1 

8 256: 4:INT 


E L 

w 

A C C C 

X + 13+/-1 


512: ECC 


N 


D # 1 2 

(X>0) 


1024: 7:INT 


T 





DATA ECC 


IDENT Definition: 

FE = Cylinders 0-255 
FF * Cylinders 256-51 1 
FC = Cylinders 512-767 
FD = Cylinders 768-1023 
F6 = Cylinders 1024-1279 
F7 = Cylinders 1280-1535 
F4 = Cylinders 1536-1791 
F5 = Cylinders 1792-2047 


NOTES 

1 . n = contents of sector number register during 
format command. 

2. CL = controller latency. 1/2 < CL < 1-1/2 byte 
times. 

3. x = contents of PLO register. ID PLO length is 
programmable during format command. Data 
PLO length is programmable during write com- 
mand. Data PLO length is 1 1 during format. Data 
PLO length is 1 2 ± 1 (or x + 1 3 ± 1 ) during write if 
x = 0 (x > 0). 

4. twGON = 17 ± 1 bit times with respect to 
NRZRD in. 


5. twGOFFi = 28 bit times with respect to NRZWD 
out. 

6. tRGOFFi = 9 ± 1 bit times with respect to 
NRZRD in. 

7. tRGOFF 2 = 9 ± 1 bit times with respect to 
NRZRD in. 

8. tRGONi =3 + 1 bit times with respect to AMF. 

9. tRGON 2 = 35 + 1 bit times with respect to 
NRZRD in. 

10. twRREC = 21 to 35 bytes minimum. tRREC = 
23 bytes minimum. 


FIGURE 30. SOFT SECTOR NRZ TRACK FORMAT 
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Repeated for Each Sector 


SECTOR 


DRUN 


WG 

(during FORMAT) 


WG 

(during WRITE) 


RG 













l WGON — ► 


X" 


42C22A 
FORMAT 
# BYTES 


GAP 4 




GAP 1 
n + 5 + GL 


1 RGOFF+-* 
[ RGON1 


C 


1 WG0FF1 - 


I D PLO) 
X + 9 


1 rgoff; 




RGON2 " 


I D 
PAD 2 


WRITE 

SPICE 

1 


DATA PLO 
( 11 ) 


DATA 


DATA 

PAD 

3 


GAP 2 


GAP 3 
n + 5 + CLl 


ID PLO 
X + 9 


\ 


/ 


// 


\ 


A 

1 

C L 

H 

S 

c 

c 

1 

D 

Y O 

E 

E 

R 

R 


E 

L W 

A 

C 

C 

C 


N 


D 

# 

1 

2 


T 







/ 


/ L 


X + 12+/-1 
(X = 0) 

X+ 13+/- 1 
(X>0) 


A 

F 

128: 

2:CRC 

1 

8 

256: 

4:INT 



512: 

ECC 



1024: 

7:INT 



DATA 

ECC 


I DENT Definition: 

FE = Cylinders 0-255 
FF = Cylinders 256-51 1 
FC = Cylinders 512-767 
FD = Cylinders 768-1023 
F6 = Cylinders 1024-1279 
F7 = Cylinders 1280-1535 
F4 = Cylinders 1536-1791 
F5 = Cylinders 1792-2047 


NOTES 

1 . n = contents of sector number register during 
format command. 

2. CL = controller latency. 1/2 < CL < 1-1/2 byte 
times. 

3. x = contents of PLO register. ID PLO length is 
programmable during format command. Data 
PLO length is programmable during write com- 
mand. Data PLO length is 1 1 during format. Data 
PLO length is 12 ± 1 (x + 13 ± 1) during write if x 
= 0 (x > 0). 

4. twGON = 17 ± 1 bit times with respect to RD in. 

5. twGOFFi = 28 bit times with respect to WD out. 

6. tRGOFFi = 9 ± 1 bit times with respect to RD in. 


7. tRGOFF 2 = 9 ± 1 bit times with respect to RD in. 

8. tRGONi = 19 ± 1 bit times with respect to 
DRUN. SECTOR is tied to DRUNSCT during for- 
mat. DRUN is tied to DRUNSCT during read and 
write. 

9. tRGON 2 = 35 + 1 bit times with respect to RD in. 

10. GAP2 = Speed tolerance + combined 
ENDEC delays + other gap requirements, e.g. 
servo. 

GAP2 length = (time between sector pulses) - 
(time from start of GAP1/GAP3 to end of data 
pad.) 


FIGURE 31. HARD SECTOR RLL/MFM TRACK FORMAT 
(WITH SOFT SECTOR READ/WRITE) 
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Repeated for Each Sector 


INDEX 


SECTOR 




WG 

(during FORMAT) 


WG 


(during WRITE) 


RG 




1 WGON " 


WGOFF1 ' 


I * RGOFFr* 


1 rgoff; 


r-J 


42C22A 
FORMAT 
# BYTES 


'■ RGON1-* 

■ 1 

f 1 RGON2 

1 : 

GAP 4 

GAP 1 
n + 5 + CL 

ID PLO 

X + 9 

1 D 
7 

1 D 
PAD 2 

WRITE 

SPICE 

1 

DATA PLO 
(11) 

DATA 

DATA 

PAD 

3 

WS 

1 

GAP 2 

GAP 3 
n + 5 + CL 

ID PLO 
X + 9 


\ 


\ 


A 

1 

C L 

H 

S 

C 

c 

1 

D 

Y O 

E 

E 

R 

R 


E 

L W 

A 

C 

C 

C 


N 


D 

# 

1 

2 


T 









A 

F 

128: 



2:CRC 

1 

8 

256: 

4:INT 



512: 

ECC 



1024: 

7:INT 

_ 


DATA 

ECC 


I DENT Definition: 

FE = Cylinders 0-255 
FF = Cylinders 256-51 1 
FC = Cylinders 512-767 
FD = Cylinders 768-1023 
F6 = Cylinders 1024-1279 
F7 = Cylinders 1280-1535 
F4 = Cylinders 1536-1791 
F5 = Cylinders 1792-2047 


NOTES 

1 . n = contents of sector number register during 
format command. 

2. CL = controller latency. 1/2 < CL < 1-1/2 byte 
times. 

3. x = contents of PLO register. ID PLO length is 
programmable during format command. Data 
PLO length is programmable during write com- 
mand. Data PLO length is 1 1 during format. Data 
PLO length is 1 2 ± 1 (x + 1 3 ± 1 ) during write if x 
= 0 (x > 0). 

4. twGON = 17 ± 1 bit times with respect to RD in. 

5. twGOFFi = 28 bit times with respect to WD out. 

6. tRGOFFi = 9 ± 1 bit times with respect to RD in. 


7. tRGOFF2 = 9 + 1 bit times with respect to RD in. 

8. tRGONi = z + CL byte times with respect to 
INDEX/SECTOR (SCT). SECTOR is tied to 
DRUNSCT always, z = contents of internal GAP 
register. 

9. tRGON2 = 35 + 1 bit times with respect to RD in. 

10. GAP2 = Speed tolerance + combined 
ENDEC delays + other gap requirements, e.g. 
servo. 

GAP2 length = (time between sector pulses) - 
(time from start of GAP1/GAP3 to end of data 
pad.) 


FIGURE 32. HARD SECTOR RLL/MFM TRACK FORMAT 

(WITH HARD SECTOR READ/WRITE AND 
CONTINUOUS WG OPTION) 
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Repeated for Each Sector 


J/“A_ 





42C22A 
FORMAT 
# BYTES 


GAP 4 

GAP 1 

WS 

ID PLO 

1 D 

1 D 

WRITE 

DATA PLO 

DATA 

DATA 

WS 

GAP 2 

GAP 3 

WS 

ID PLO 


n + 5 + CL 

1 

X + 8 

7 

PAD 2 

SPICE 

1 

(11) 


PAD 

3 

1 


n + 5 + CL 

1 

X + 8 


\ 


4 


A 

1 

C L 

H 

S 

c 

c 

1 

D 

Y O 

E 

E 

R 

R 


E 

L W 

A 

C 

C 

C 


N 


D 

# 

1 

2 

_ 

LD 


_ 





/ / 


X + 12+/-1 
(X = 0) 

X + 13 +/- 1 
(X>0) 


A 

F 

128: 

2:CRC 

1 

8 

256: 

4:INT 



512: 

ECC 



1024: 

7:INT 

_ 


DATA 

ECC 


IDENT Definition: 

FE = Cylinders 0-255 
FF = Cylinders 256-51 1 
FC = Cylinders 51 2-767 
FD = Cylinders 768-1023 
F6 = Cylinders 1024-1279 
F7 = Cylinders 1280-1535 
F4 = Cylinders 1536-1 791 
F5 = Cylinders 1 792-2047 


NOTES 

1 . n = contents of sector number register during 
format command. 

2. CL = controller latency. 1/2 < CL < 1-1/2 byte 
times. 

3. x = contents of PLO register. ID PLO length is 
programmable during format command. Data 
PLO length is programmable during write com- 
mand. Data PLO length is 1 1 during format. Data 
PLO length is 12+1 (or x + 1 3 ± 1 ) during write if 
x = 0 (x > 0). 

4. twGON = 17 + 1 bit times with respect to RD in. 

5. twGOFFi = 28 bit times with respect to WD out. 

6. tRGOFFi = 9 ± 1 bit times with respect to RD in. 

7. tRGOFF2 = 9 + 1 bit times with respect to RD in. 


8. tRGONi = z + CL byte times with respect to 
INDEX/SECTOR (SCT). SECTOR is tied to 
DRUNSCT always, z = contents of internal GAP 
register. 

9. tRGON 2 = 35 + 1 bit times with respect to RD in. 

10. GAP2 = Speed tolerance + combined 
ENDEC delays + other gap requirements, e.g. 
servo. 

GAP2 length = (time between sector pulses) - 
(time from start of GAP1/GAP3 to end of data 
pad.) 

1 1 ■ tFWGON = n + 5 + CL byte times with respect 
to INDEX/SECTOR. twGOFF = 20 bit times with 
respect to WD out. 


FIGURE 33. HARD SECTOR RLL/MFM TRACK FORMAT 


(WITH HARD SECTOR READ/WRITE AND WG PULSE) 




ADVANCED INFORMATION 12/4/90 


33-89 






WD42C22C 


ELECTRICAL AND TIMING SPECIFICATIONS 


Repeated for Each Sector 


Ik* WGLOW 


/, t 

1 RG0FF1 


4 1 RG0N2 - 

ID ID 1 WRITE 
7 PAD 2 SPICE 


I C L H S C C 

D Y O E E R R 

E L W A C C C 




A F 128: 

2:CRC 

1 8 256: 

4:INT 

512: 

ECC 

1024: 

7:INT 

DATA 

ECC 


NOTES 

1 . n = contents of sector number register during 
format command. 

2. CL = controller latency. 1/2 < CL < 1-1/2 byte 
times. 

3. x = contents of PLO register. ID PLO length is 
programmable during format command. Data 
PLO length is programmable during write com- 
mand. Data PLO length is 1 1 during format. Data 
PLO length is 1 2 + 1 (or x + 1 3 ± 1 ) during write if 
x = 0. 

4. twGON = 17 + 1 bit times with respect to 
NRZRD in. 

5. twGOFFi = 28 bit times with respect to NRZWD 
out. 

6. tRGOFFi = 9 ± 1 bit times with respect to 
NRZRD in. 


IDENT Definition: 

FE = Cylinders 0-255 
FF = Cylinders 256-51 1 
FC = Cylinders 512-767 
FD = Cylinders 768-1023 
F6 = Cylinders 1024-1279 
F7 = Cylinders 1280-1535 
F4 = Cylinders 1536-1 791 
F5 = Cylinders 1792-2047 


7. tRGOFF2 = 9 ± 1 bit times with respect to 
NRZRD in. 

8. tRGONi = z + CL byte times with respect to 
INDEX/SECTOR (SCT). z = contents of internal 
GAP register. 

9. tRGON 2 = 35 + 1 bit times with respect to 
NRZRD in. 

10. t wglow = 2 bit times. twGOFF2 = 8 bit times. 
Both timings with respect to NRZWD out. 

1 1 . GAP2 = Speed tolerance + combined 
ENDEC delays + other gap requirements, e.g. 
servo. 

GAP2 length = (time between sector pulses) - 
(time from start of GAP1/GAP3 to end of data 
pad.) 


FIGURE 34. HARD SECTOR NRZ TRACK FORMAT 
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5.4 PACKAGE DIAGRAMS 




FIGURE 35. 84-LEAD PLCC 
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